Java數(shù)組的運(yùn)用詳解
一,數(shù)組的含義:
一維數(shù)組:相同數(shù)據(jù)類型的元素的集合。
二位數(shù)組:存放數(shù)組的數(shù)組,也就是說(shuō)數(shù)組里存的還是數(shù)組的數(shù)據(jù)形式。
二,數(shù)組的創(chuàng)建
一維數(shù)組
1,動(dòng)態(tài)初始化
數(shù)據(jù)類型[] 數(shù)組名 = new 數(shù)據(jù)類型[數(shù)組長(zhǎng)度];
例:int[] a = new int[5];
2,靜態(tài)初始化
數(shù)據(jù)類型[] 數(shù)組名 = {數(shù)組0,數(shù)組1,數(shù)組2,數(shù)組3,…};
例:int[] b = new int[]{1,2,3,4,5};
數(shù)據(jù)類型[] 數(shù)組名 = {數(shù)組0,數(shù)組1,數(shù)組2,數(shù)組3,…};
例:int[] c = {1,2,3,4,5}
二位數(shù)組
數(shù)據(jù)類型[][] 數(shù)組名 = {數(shù)組1,數(shù)組2,…};
例:int[][] a = {{3,5},{7,9},{1,2}};

三,數(shù)組遍歷
一維數(shù)組遍歷
int [] arr={1,2,3,4,5};
for(int a = 0; a < arr.length; a++){
System.out.print(arr[a]);
}
運(yùn)行結(jié)果:
12345
Arrays工具類中toString靜態(tài)方法遍歷
int [] arr={1,2,3,4,5};
System.out.print(Arrays.toString(arr));
運(yùn)行結(jié)果:
[1, 2, 3, 4, 5]
二維數(shù)組遍歷
int Arr[][]={{5,7,15},{8,4,11},{3,6,13}};
for (int i = 0; i < Arr.length; i++) {
for (int j = 0; j < Arr[i].length; j++) {
System.out.print(Arr[i][j]+" ");
}
}
運(yùn)行結(jié)果:
5 7 15 8 4 11 3 6 13
Arrays工具類中deepToString靜態(tài)方法遍歷
int b[][]={{5,7,15},{8,4,11},{3,6,13}};
System.out.println(Arrays.deepToString(b));
運(yùn)行結(jié)果:
[[5, 7, 15], [8, 4, 11], [3, 6, 13]]
四,Arrays.deepToString()與Arrays.toString()的區(qū)別
Arrays.deepToString()主要用于數(shù)組中還有數(shù)組的情況,而Arrays.toString()則相反,對(duì)于Arrays.toString()而言,當(dāng)數(shù)組中有數(shù)組時(shí),不會(huì)打印出數(shù)組中的內(nèi)容,只會(huì)以地址的形式打印出來(lái)。
例:
int a[][]={{5,7,15},{8,4,11},{3,6,13}};
System.out.println(Arrays.toString(a));
int b[][]={{1,2,3},{8,4,11},{3,6,13}};
System.out.println(Arrays.deepToString(b));
運(yùn)行結(jié)果:
[[I@da2dbb, [I@176fe71, [I@fb509a]
[[1, 2, 3], [8, 4, 11], [3, 6, 13]]
五,Java中Arrays類的常用方法
Arrays類位于 java.util 包中,主要包含了操作數(shù)組的各種方法。
Arrays.fill(); //填充數(shù)組
int[] a = new int[5];//新建一個(gè)大小為5的數(shù)組 Arrays.fill(a,4);//給所有值賦值4 System.out.println(Arrays.toString(a)); int[] b = new int[5];//新建一個(gè)大小為5的數(shù)組 Arrays.fill(b, 2,4,1);//給第2位(0開始)到第4位(不包括)賦值6 System.out.println(Arrays.toString(b));
運(yùn)行結(jié)果:
[4, 4, 4, 4, 4]
[0, 0, 1, 1, 0]
Arrays.sort(); //數(shù)組排序
1,數(shù)字排序
int[] a = new int[] { 4, 1, 3, -2, 10 };
Arrays.sort(a);
System.out.println(Arrays.toString(a));
運(yùn)行結(jié)果:
[-2, 1, 3, 4, 10]
2,字符串排序,先大寫后小寫
String[] a = new String[] { "a", "b", "C" };
Arrays.sort(a);
System.out.println(Arrays.toString(a));
運(yùn)行結(jié)果:
[C, a, b]
3,嚴(yán)格按字母表順序排序,也就是忽略大小寫排序 CASE_INSENSITIVE_ORDER
String[] a = new String[] { "a", "b", "C" };
Arrays.sort(a, String.CASE_INSENSITIVE_ORDER);
System.out.println(Arrays.toString(a));
運(yùn)行結(jié)果:
[a, b, C]
4,反向排序, Collections.reverseOrder()
String[] a = new String[] { "a", "b", "C" };
Arrays.sort(a, Collections.reverseOrder());
System.out.println(Arrays.toString(a));
運(yùn)行結(jié)果:
[a, b, C]
5,忽略大小寫反向排序 (先忽略大小寫,再反向排序)
String[] a = new String[] { "a", "B", "c","D" };
Arrays.sort(a, String.CASE_INSENSITIVE_ORDER);
Collections.reverse(Arrays.asList(a));
System.out.println(Arrays.toString(a));
運(yùn)行結(jié)果:
[D, c, B, a]
6,選擇數(shù)組指定位置進(jìn)行排序
int[] a = {3,2,1,8,6,5,4,7};
Arrays.sort(a,0,3);//給第0位(0開始)到第3位(不包括)排序
System.out.print(Arrays.toString(a));
運(yùn)行結(jié)果:
[1, 2, 3, 8, 6, 5, 4, 7]
Arrays.toString(); //將數(shù)組中的內(nèi)容全部打印出來(lái)
int[] a = {3,2,1,5,4};
System.out.println(a);//直接將數(shù)組打印輸出
String str = Arrays.toString(a); // Arrays類的toString()方法能將數(shù)組中的內(nèi)容全部打印出來(lái)
System.out.println(str);
運(yùn)行結(jié)果:
[I@da2dbb
[3, 2, 1, 5, 4]
Arrays.equals(); //比較數(shù)組元素是否相等
int[] arr1 = {1,2,3};
int[] arr2 = {1,2,3};
System.out.println(Arrays.equals(arr1,arr2));
System.out.println(arr1.equals(arr2));
運(yùn)行結(jié)果:
true
false
因?yàn)閑quals比較的是兩個(gè)對(duì)象的地址,不是里面的數(shù),而Arrays.equals重寫了equals,所以,這里能比較元素是否相等。
Arrays.copyOf();//復(fù)制數(shù)組
int[] a= {3, 7, 2, 1};
int[] b=Arrays.copyOf(arr6, 4); //指定新數(shù)組的長(zhǎng)度
int[] c=Arrays.copyOfRange(a, 1, 3); //只復(fù)制從索引[1]到索引[3]之間的元素(不包括索引[3]的元素)
System.out.println(Arrays.toString(b));
System.out.println(Arrays.toString(c));
運(yùn)行結(jié)果:
[3, 7, 2, 1]
[7, 2]
數(shù)組中是否包含某一個(gè)值
String[] array={"aaa","bbb","ccc","ddd","eee"};
String a="aaa";
String b="fff";
if (Arrays.asList(array).contains(a)) {
System.out.println("1");
}else {
System.out.println("2");
}
if (Arrays.asList(array).contains(b)) {
System.out.println("1");
}else {
System.out.println("2");
}
運(yùn)行結(jié)果:
1
2
其它方法,詳情見(jiàn)JAVA JDK_API






六,數(shù)組去重
1,利用set的特性去重
int[] arr11 = {1,2,3,4,5,6,7,8,9,0,3,2,4,5,6,7,4,32,2,1,1,4,6,3};
Set<Integer> set2=new HashSet<Integer>();
for (int i = 0; i < arr11.length; i++) {
set2.add(arr11[i]);
}
System.out.println(set2);
int[] arr12 = new int[set2.size()];
int j=0;
for (Integer i:set2) {
arr12[j++]=i;
}
System.out.println(Arrays.toString(arr12));
運(yùn)行結(jié)果:
[0, 32, 1, 2, 3, 4, 5, 6, 7, 8, 9]
[0, 32, 1, 2, 3, 4, 5, 6, 7, 8, 9]
2,用List集合實(shí)現(xiàn)
int[] str = {5, 6, 6, 6, 8, 8, 7,4};
List<Integer> list = new ArrayList<Integer>();
for (int i=0; i<str.length; i++) {
if(!list.contains(str[i])) {
list.add(str[i]);
}
}
System.out.println("去除重復(fù)后的list集合"+list);
運(yùn)行結(jié)果:
[5, 6, 8, 7, 4]
3,用hashSet或者TreeSet實(shí)現(xiàn)
Integer[] nums = { 5, 5, 6, 6, 6, 8, 8, 7, 11, 12, 12 };
HashSet hset = new HashSet(Arrays.asList(nums));
//TreeSet<Integer> hset = new TreeSet<Integer>(Arrays.asList(nums));
Iterator i = hset.iterator();
while(i.hasNext()){
System.out.print(i.next());
}
運(yùn)行結(jié)果:
56781112
4,用List和set實(shí)現(xiàn)
int[] nums = { 5, 6, 6, 6, 8, 8, 7 };
List<Integer> numList = new ArrayList<Integer>();
for (int i : nums)
numList.add(i);
Set<Integer> numSet = new HashSet<Integer>();
numSet.addAll(numList);
System.out.println(numSet);
運(yùn)行結(jié)果:
[5, 6, 7, 8]
七,數(shù)組刪除,增加元素
刪除數(shù)組中其中一個(gè)元素
String [] str = {"Java", "C++", "Php", "C#", "Python"};//刪除php
List<String> list = new ArrayList<String>();
for (int i=0; i<str.length; i++) {
list.add(str[i]);
}
list.remove(2); //list.remove("Php")
String[] newStr = list.toArray(new String[1]); //返回一個(gè)包含所有對(duì)象的指定類型的數(shù)組
System.out.println(Arrays.toString(newStr));
運(yùn)行結(jié)果:
[Java, C++, C#, Python]
在數(shù)組中增加一個(gè)元素
String [] str = {"Java", "C++", "Php", "C#", "Python"};//增加ruby
List<String> list = new ArrayList<String>();
for (int i=0; i<str.length; i++) {
list.add(str[i]);
}
list.add(2, "ruby");
String[] newStr = list.toArray(new String[1]); //返回一個(gè)包含所有對(duì)象的指定類型的數(shù)組
System.out.println(Arrays.toString(newStr));
運(yùn)行結(jié)果:
[Java, C++, ruby, Php, C#, Python]
八,數(shù)組與List相互轉(zhuǎn)換
數(shù)組轉(zhuǎn) List ,使用 JDK 中 java.util.Arrays 工具類的 asList 方法
String[] strs = new String[] {"aaa", "bbb", "ccc"};
List<String> list = Arrays.asList(strs);
for (String s : list) {
System.out.println(s);
}
List 轉(zhuǎn)數(shù)組,使用 List 的toArray方法。無(wú)參toArray方法返回Object數(shù)組,傳入初始化長(zhǎng)度的數(shù)組對(duì)象,返回該對(duì)象數(shù)組
List<String> list2 = Arrays.asList("aaa", "bbb", "ccc");
String[] array = list2.toArray(new String[list2.size()]);
for (String s : array) {
System.out.println(s);
}
總結(jié)
本篇文章就到這里了,希望能給你帶來(lái)幫助,也希望您能夠多多關(guān)注腳本之家的更多內(nèi)容!
相關(guān)文章
SpringBoot實(shí)現(xiàn)IP地址解析的示例代碼
本篇帶大家實(shí)踐在springboot項(xiàng)目中獲取請(qǐng)求的ip與詳細(xì)地址,我們的很多網(wǎng)站app中都已經(jīng)新增了ip地址顯示,具有一定的參考價(jià)值,感興趣的可以了解一下2024-01-01
java項(xiàng)目中多線程使用場(chǎng)景與實(shí)現(xiàn)方式詳解
在項(xiàng)目中,多線程的使用非常廣泛,主要用于提高程序的并發(fā)性和響應(yīng)速度,本文為大家整理了一些常見(jiàn)的多線程使用場(chǎng)景以及相應(yīng)的實(shí)現(xiàn)方式,希望對(duì)大家有一定的幫助2025-04-04
SpringBoot限制接口訪問(wèn)頻率功能實(shí)現(xiàn)
最近在基于SpringBoot做一個(gè)面向普通用戶的系統(tǒng),為了保證系統(tǒng)的穩(wěn)定性,防止被惡意攻擊,我想控制用戶訪問(wèn)每個(gè)接口的頻率,接下來(lái)通過(guò)本文給大家介紹SpringBoot限制接口訪問(wèn)頻率功能實(shí)現(xiàn),需要的朋友可以參考下2023-05-05
兩種JAVA實(shí)現(xiàn)短網(wǎng)址服務(wù)算法
這篇文章介紹了兩種JAVA實(shí)現(xiàn)短網(wǎng)址服務(wù)算法,一種是基于MD5碼的,一種是基于自增序列的,需要的朋友可以參考下2015-07-07
JavaWeb動(dòng)態(tài)導(dǎo)出Excel可彈出下載
這篇文章主要介紹了JavaWeb動(dòng)態(tài)導(dǎo)出Excel,對(duì)Excel可彈出進(jìn)行下載操作,感興趣的小伙伴們可以參考一下2016-03-03
從log4j切換到logback后項(xiàng)目無(wú)法啟動(dòng)的問(wèn)題及解決方法
這篇文章主要介紹了從log4j切換到logback后項(xiàng)目無(wú)法啟動(dòng)的問(wèn)題及解決方法,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2023-01-01
@TransactionalEventListener的使用和實(shí)現(xiàn)原理分析
這篇文章主要介紹了@TransactionalEventListener的使用和實(shí)現(xiàn)原理分析,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-12-12

