Java数组定义常用方法
- JAVA认证
- 关注:2.55W次
Java中的数组、是一种简单的线性数据存储结构、他用牺牲自动扩展大小来换取与集合相比的唯一优势——查询效率的提升。Java中的数组有什么类型?我们要怎么定义这些数组呢?下面跟yjbys小编一起来学习Java数组定义常用方法吧!
java中有两种数据类型:
a)引用类型
b)基础类型
其中基础类型又有两种:
b1)数值类型
b2)及布尔类型。
数组——也为java的一个数据类型、归类为引用类型。本文意图说清楚两点:
1、数组的声明以及初始化。
2、常用的数组方法。
补充一点:对于我们常说的二维数组、多维数组其实是一维数组的延伸、这里暂时只围绕一维数组。
【数组的声明及初始化】
1、数组的声明:
作为一种引用类型、就如我们平常使用引用类型的时候声明一样、一般有两种写法:
a) type[] arrayName; exp: String[] strArray;
b) type arrayName[]; exp: String strArray[];
第二种源于C的写法、由于很容易造成混淆、所以现在基本不使用这种声明方式了。
2、数组的初始化:
数组的初始化有两种:
a) 静态初始化——数组大小由系统分配、我们只为数组每个位置上赋值
String[] strArray1 = {"a", "b", "c", "d", "e"};
String[] strArray2 = new String[]{"a", "b", "c", "d", "e"};//在 new String[]中不能指定String数组的大小!
b)动态初始化——只指定数值的大小、初始化工作由系统为我们完成(即为数组的.每个位置赋初始值)
String[] strArray3 = new String[5];//此时String数组的每个位置上的值都由系统来初始化、使用默认的值""
//我们能做的是动态的为strArray3每个位置上的值进行修改
for (int i = 0; i < th; i++) {
//这里仅用原始的方法进行赋值。
strArray3[i] = strArray1[i];
}
【数组的常用方法】
package ulMethods;
import yList;
import ys;
import ections;
import Set;
import ;
import ent;
@SuppressWarnings("all")
public class ArrayUseFulMethoed {
private static int[] intArray = {1, 2, 3, 4, 5};
private static String[] strArray = {"a", "b", "c", "d", "e"};
/**
* 填充元素、比较大小、复制元素
*/
public static void testFillArray(){
//注意字符串和对象的不同
Student[] student1 = new Student[4];
Student[] student2 = new Student[4];
tln(ls(student1, student2));//true
(student1, 0, 4, new Student(1,"chy"));
(student2, new Student(1,"chy"));
tln(ls(student1, student2));//false
String[] str1 = new String[4];
String[] str2 = new String[]{"a", "a", "a", "a"};
String[] str3 = {new String("a"), new String("a"), new String("a"), new String("a")};
(str1, "a");
tln(ls(str1, str2));//true
tln(ls(str2, str3));//true
String[] str4 = Of(str1, 2);//是将传入的数组拷贝len个元素到新的数组、相当于复制本身的一部分或者全部形成一个全新的数组
tln(th + "=======" + ring(str4));// 2=======[a, a]
String[] str5 = new String[8];
ycopy(str4, 0, str5, 6, 2);//是将str4从下标0开的2个元素拷贝到从下标6开始放置的数组str5中
tln(th + "=======" + ring(str5));// 8=======[null, null, null, null, null, null, a, a]
}
/**
* 以字符串的形式输出指定数组的“模样”
*/
public static void printOriginalArray(){
String intArrayToString = ring(intArray);
tln(intArrayToString); //result: [1, 2, 3, 4, 5]
}
/**
* 将数组转化成List集合
* 注意:不能直接将int[]转化为集合、因为asList()方法的参数必须是对象。应该先把int[]转化为Integer[]。
* 对于其他primitive类型的数组也是如此,必须先转换成相应的wrapper类型数组。
*/
public static void convetArrayToList(){
Integer[] integerArray = new Integer[th];
for (int i = 0; i < th; i++) {
integerArray[i] = intArray[i];
}
ArrayList integerList1 = new ArrayList(st(integerArray));
/*
* 不能写成下面:
* ArrayList integerList2 = (ArrayList)st(integerArray);
* 返回的是List、强转可以通过编译、但是不能正常使用。
*/
for(int i : integerList1){
t(i);
}
//result: 12345
tln();
}
/**
* 将List集合转换成数组
*/
public static void convetListToArray(){
ArrayList strList = new ArrayList(st(strArray));
String[] strArrayFromList = new String[()];
ray(strArrayFromList);
tln(ring(strArrayFromList)); //result: [a, b, c, d, e]
/*
* 注意:不能写成这样:String[] strArrayFromList = (String[])ray(strArrayFromList);会抛出ClassCastException。
* ray()与ray(T[] t)的区别在于:
* ray()返回的是一个Object[]、不能强转成String[]、强转的话可以通过编译、但是不能进行String[]的操作
* 而ray(T[] t)会将list的值转换成T类型的数组。
*/
}
/**
* 将数组转换成Set集合
*/
public static void convertArrayToSet(){
Set set = new HashSet(st(strArray));
//Set具有无序性、所以输出结构不一定是原来数组元素存放顺序
tln(set); //result: [d, e, b, c, a]
}
/**
* 判断某个数组中是否包含一个元素、思路:将数组转换成list使用list的contains方法
*/
public static void isContainObject(){
ArrayList strList = new ArrayList(st(strArray));
tln(ains("a")); //result: true
//另一种实现
(strArray);
if(rySearch(strArray, "c") >= 0){
tln(true);
}else{
tln(false);
}
}
/**
* 将两个相同类型的数组连接起来
*/
public static void connTwoSameArray(){
int[] intArray2 = new int[]{6, 7, 8, 9, 10};
}
/**
* 将数组中数据排序
*/
public static void sortArray(){
String[] str = {"c", "a" ,"d" ,"z" };
(str);
tln(ring(str));
//反序、
(str, rseOrder());
tln(ring(str));
}
public static void main(String[] args) {
/*printOriginalArray();
convetArrayToList();
convetListToArray();
isContainObject();
convertArrayToSet();
sortArray();*/
testFillArray();
}
}
- 文章版权属于文章作者所有,转载请注明 https://xuezhezhai.com/itrz/java/qv4p5r.html