Java之Arrays的各種功能和用法總結(jié)
前言
數(shù)組在 Java 中是一種常用的數(shù)據(jù)結(jié)構(gòu),用于存儲(chǔ)和操作大量數(shù)據(jù)。但是在處理數(shù)組中的數(shù)據(jù),可能會(huì)變得復(fù)雜和繁瑣。Arrays 是我們?cè)谔幚頂?shù)組時(shí)的一把利器。它提供了豐富的方法和功能,使得數(shù)組操作變得更加簡(jiǎn)單、高效和可靠。無(wú)論是排序、搜索、比較還是復(fù)制,Arrays 都能夠滿足我們的需求,來(lái)幫助我們充分發(fā)揮數(shù)組的潛力。接下來(lái)我們一起看看 Arrays 的各種功能和用法,以幫助我們更好地利用這個(gè)強(qiáng)大的工具。
asList()- 轉(zhuǎn)換為固定大小列表:將指定的元素轉(zhuǎn)換為一個(gè)固定大小的列表。binarySearch()- 二分查找:在指定數(shù)組中使用二分查找算法查找指定元素。copyOf()- 復(fù)制數(shù)組:將指定數(shù)組的副本復(fù)制到一個(gè)新數(shù)組中。copyOfRange()- 范圍復(fù)制數(shù)組:將指定數(shù)組的指定范圍內(nèi)的元素復(fù)制到一個(gè)新數(shù)組中。fill()- 填充數(shù)組:將指定的值填充到數(shù)組的每個(gè)元素中。equals()- 比較數(shù)組相等性:比較兩個(gè)數(shù)組是否相等。setAll()- 設(shè)置所有元素:使用指定的生成器函數(shù)設(shè)置數(shù)組的元素值。sort()- 排序數(shù)組:對(duì)指定數(shù)組進(jìn)行升序排序。stream()- 轉(zhuǎn)換為流:將數(shù)組轉(zhuǎn)換為流。spliterator()- 分割迭代器:創(chuàng)建一個(gè)用于遍歷數(shù)組元素的分割迭代器。parallelPrefix()- 并行前綴:對(duì)數(shù)組中的元素進(jìn)行累積操作,將結(jié)果存儲(chǔ)在數(shù)組中。parallelSetAll()- 并行設(shè)置所有元素:使用指定的生成器函數(shù)并行地設(shè)置數(shù)組的元素值。parallelSort()- 并行排序:對(duì)指定數(shù)組進(jìn)行并行排序。hashCode()- 哈希碼值:返回?cái)?shù)組的哈希碼值。deepHashCode()- 多維數(shù)組的哈希碼值:返回多維數(shù)組的哈希碼值。deepToString()- 多維數(shù)組的字符串表示形式:返回多維數(shù)組的字符串表示形式。toString()- 數(shù)組的字符串表示形式:返回?cái)?shù)組的字符串表示形式。
代碼示例
1. asList() - 轉(zhuǎn)換為固定大小列表:
import java.util.Arrays;
import java.util.List;
public class AsListExample {
public static void main(String[] args) {
String[] array = {"A", "B", "C"};
System.out.println("原始數(shù)組: " + Arrays.toString(array));
List<String> list = Arrays.asList(array);
System.out.println("轉(zhuǎn)換后的列表: " + list);
}
}輸出結(jié)果:
原始數(shù)組: [A, B, C]
轉(zhuǎn)換后的列表: [A, B, C]
2. binarySearch() - 二分查找:
import java.util.Arrays;
public class BinarySearchExample {
public static void main(String[] args) {
int[] numbers = {2, 4, 6, 8, 10};
int key = 6;
System.out.println("數(shù)組: " + Arrays.toString(numbers));
int index = Arrays.binarySearch(numbers, key);
System.out.println("要查找的元素: " + key);
System.out.println("元素的索引位置: " + index);
}
}輸出結(jié)果:
數(shù)組: [2, 4, 6, 8, 10]
要查找的元素: 6
元素的索引位置: 2
3. copyOf() - 復(fù)制數(shù)組:
import java.util.Arrays;
public class CopyOfExample {
public static void main(String[] args) {
int[] sourceArray = {1, 2, 3};
System.out.println("源數(shù)組: " + Arrays.toString(sourceArray));
int[] copyArray = Arrays.copyOf(sourceArray, sourceArray.length);
System.out.println("復(fù)制后的數(shù)組: " + Arrays.toString(copyArray));
}
}輸出結(jié)果:
源數(shù)組: [1, 2, 3]
復(fù)制后的數(shù)組: [1, 2, 3]
4.
copyOfRange()- 范圍復(fù)制數(shù)組:
import java.util.Arrays;
public class CopyOfRangeExample {
public static void main(String[] args) {
int[] sourceArray = {1, 2, 3, 4, 5};
System.out.println("源數(shù)組: " + Arrays.toString(sourceArray));
int[] copyArray = Arrays.copyOfRange(sourceArray, 1, 4);
System.out.println("復(fù)制后的數(shù)組: " + Arrays.toString(copyArray));
}
}輸出結(jié)果:
源數(shù)組: [1, 2, 3, 4, 5]
復(fù)制后的數(shù)組: [2, 3, 4]
5. fill() - 填充數(shù)組:
import java.util.Arrays;
public class FillExample {
public static void main(String[] args) {
int[] arrayToFill = new int[5];
System.out.println("原始數(shù)組: " + Arrays.toString(arrayToFill));
int valueToFill = 10;
Arrays.fill(arrayToFill, valueToFill);
System.out.println("填充后的數(shù)組: " + Arrays.toString(arrayToFill));
}
}輸出結(jié)果:
原始數(shù)組: [0, 0, 0, 0, 0]
填充后的數(shù)組: [10, 10, 10, 10, 10]
6. equals() - 比較數(shù)組相等性:
import java.util.Arrays;
public class EqualsExample {
public static void main(String[] args) {
int[] array1 = {1, 2, 3};
int[] array2 = {1, 2, 3};
System.out.println("數(shù)組1: " + Arrays.toString(array1));
System.out.println("數(shù)組2: " + Arrays.toString(array2));
boolean areEqual = Arrays.equals(array1, array2);
System.out.println("數(shù)組1和數(shù)組2是否相等: " + areEqual);
}
}輸出結(jié)果:
數(shù)組1: [1, 2, 3]
數(shù)組2: [1, 2, 3]
數(shù)組1和數(shù)組2是否相等: true
7. setAll() - 設(shè)置所有元素:
import java.util.Arrays;
public class SetAllExample {
public static void main(String[] args) {
int[] arrayToSet = new int[5];
System.out.println("原始數(shù)組: " + Arrays.toString(arrayToSet));
Arrays.setAll(arrayToSet, i -> i * 2);
System.out.println("設(shè)置后的數(shù)組: " + Arrays.toString(arrayToSet));
}
}輸出結(jié)果:
原始數(shù)組: [0, 0, 0, 0, 0]
設(shè)置后的數(shù)組: [0, 2, 4, 6, 8]
8. sort() - 排序數(shù)組:
import java.util.Arrays;
public class SortExample {
public static void main(String[] args) {
int[] arrayToSort = {5, 2, 8, 1, 6};
System.out.println("原始數(shù)組: " + Arrays.toString(arrayToSort));
Arrays.sort(arrayToSort);
System.out.println("排序后的數(shù)組: " + Arrays.toString(arrayToSort));
}
}輸出結(jié)果:
原始數(shù)組: [5, 2, 8, 1, 6]
排序后的數(shù)組: [1, 2, 5, 6, 8]
9. stream() - 轉(zhuǎn)換為流:
import java.util.Arrays;
public class StreamExample {
public static void main(String[] args) {
int[] arrayToStream = {1, 2, 3, 4, 5};
System.out.println("數(shù)組: " + Arrays.toString(arrayToStream));
Arrays.stream(arrayToStream).forEach(System.out::println);
}
}輸出結(jié)果:
數(shù)組: [1, 2, 3, 4, 5]
1
2
3
4
5
10. spliterator() - 分割迭代器:
import java.util.Arrays;
public class SpliteratorExample {
public static void main(String[] args) {
int[] arrayToSplit = {1, 2, 3, 4, 5};
System.out.println("數(shù)組: " + Arrays.toString(arrayToSplit));
Arrays.spliterator(arrayToSplit).forEachRemaining((Consumer<Integer>) System.out::println);
}
}輸出結(jié)果:
數(shù)組: [1, 2, 3, 4, 5]
1
2
3
4
5
11. parallelPrefix() - 并行前綴:
import java.util.Arrays;
public class ParallelPrefixExample {
public static void main(String[] args) {
int[] arrayToPrefix = {1, 2, 3, 4, 5};
System.out.println("原始數(shù)組: " + Arrays.toString(arrayToPrefix));
Arrays.parallelPrefix(arrayToPrefix, (a, b) -> a * b);
System.out.println("并行前綴數(shù)組: " + Arrays.toString(arrayToPrefix));
}
}輸出結(jié)果:
原始數(shù)組: [1, 2, 3, 4, 5]
并行前綴數(shù)組: [1, 2, 6, 24, 120]
12. parallelSetAll() - 并行設(shè)置所有元素:
import java.util.Arrays;
public class ParallelSetAllExample {
public static void main(String[] args) {
int[] arrayToSetAll = new int[5];
System.out.println("原始數(shù)組: " + Arrays.toString(arrayToSetAll));
Arrays.parallelSetAll(arrayToSetAll, i -> i * 3);
System.out.println("設(shè)置后的數(shù)組: " + Arrays.toString(arrayToSetAll));
}
}輸出結(jié)果:
原始數(shù)組: [0, 0, 0, 0, 0]
設(shè)置后的數(shù)組: [0, 3, 6, 9, 12]
13. parallelSort() - 并行排序:
import java.util.Arrays;
public class ParallelSortExample {
public static void main(String[] args) {
int[] arrayToParallelSort = {5, 2, 8, 1, 6};
System.out.println("原始數(shù)組: " + Arrays.toString(arrayToParallelSort));
Arrays.parallelSort(arrayToParallelSort);
System.out.println("排序后的數(shù)組: " + Arrays.toString(arrayToParallelSort));
}
}輸出結(jié)果:
原始數(shù)組: [5, 2, 8, 1, 6]
排序后的數(shù)組: [1, 2, 5, 6, 8]
14. hashCode() - 哈希碼值:
import java.util.Arrays;
public class HashCodeExample {
public static void main(String[] args) {
int[] arrayToHash = {1, 2, 3};
System.out.println("數(shù)組: " + Arrays.toString(arrayToHash));
int hashCode = Arrays.hashCode(arrayToHash);
System.out.println("數(shù)組的哈希碼值: " + hashCode);
}
}輸出結(jié)果:
數(shù)組: [1, 2, 3]
數(shù)組的哈希碼值: 30817
15. deepHashCode() - 多維數(shù)組的哈希碼值:
import java.util.Arrays;
public class DeepHashCodeExample {
public static void main(String[] args) {
int[][] multiDimensionalArray = {{1, 2}, {3, 4}};
System.out.println("多維數(shù)組: " + Arrays.deepToString(multiDimensionalArray));
int deepHashCode = Arrays.deepHashCode(multiDimensionalArray);
System.out.println("多維數(shù)組的哈希碼值: " + deepHashCode);
}
}輸出結(jié)果:
多維數(shù)組: [[1, 2], [3, 4]]
多維數(shù)組的哈希碼值: 32833
16. deepToString() - 多維數(shù)組的字符串表示形式:
import java.util.Arrays;
public class DeepToStringExample {
public static void main(String[] args) {
int[][] multiDimensionalArray = {{1, 2}, {3, 4}};
System.out.println("多維數(shù)組: " + Arrays.deepToString(multiDimensionalArray));
}
}輸出結(jié)果:
多維數(shù)組: [[1, 2], [3, 4]]
17. toString() - 數(shù)組的字符串表示形式:
import java.util.Arrays;
public class ToStringExample {
public static void main(String[] args) {
int[] arrayToString = {1, 2, 3};
System.out.println("數(shù)組: " + Arrays.toString(arrayToString));
}
}輸出結(jié)果:
數(shù)組: [1, 2, 3]
結(jié)尾
如果覺(jué)得對(duì)你有幫助,可以多多評(píng)論,多多點(diǎn)贊哦,也可以到我的主頁(yè)看看,說(shuō)不定有你喜歡的文章,也可以隨手點(diǎn)個(gè)關(guān)注哦,謝謝。
以上就是Java之Arrays的各種功能和用法總結(jié)的詳細(xì)內(nèi)容,更多關(guān)于Java Arrays功能和用法的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
關(guān)于SpringBoot使用@ExceptionHandler注解局部異常處理
這篇文章主要介紹了關(guān)于SpringBoot使用@ExceptionHandler注解局部異常處理,SpringBoot提供了多種方式來(lái)處理異常,在本文中,我們將介紹SpringBoot中的@ExceptionHandler注解,演示如何使用它進(jìn)行局部異常處理2023-07-07
Java使用動(dòng)態(tài)規(guī)劃算法思想解決背包問(wèn)題
背包問(wèn)題(Knapsack problem)是一種組合優(yōu)化的NP完全問(wèn)題。問(wèn)題可以描述為:給定一組物品,每種物品都有自己的重量和價(jià)格,在限定的總重量?jī)?nèi),我們?nèi)绾芜x擇,才能使得物品的總價(jià)格最高2022-04-04
java多線程編程之InheritableThreadLocal
這篇文章主要為大家詳細(xì)介紹了java多線程編程之InheritableThreadLocal,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-10-10
將List集合中的map對(duì)象轉(zhuǎn)為L(zhǎng)ist<對(duì)象>形式實(shí)例代碼
這篇文章主要介紹了將List集合中的map對(duì)象轉(zhuǎn)為L(zhǎng)ist<對(duì)象>形式實(shí)例代碼,具有一定借鑒價(jià)值,需要的朋友可以參考下2018-01-01
如何只返回實(shí)體類(lèi)中的部分字段問(wèn)題
這篇文章主要介紹了如何只返回實(shí)體類(lèi)中的部分字段問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-05-05
Java的IO流實(shí)現(xiàn)文件和文件夾的復(fù)制
這篇文章主要為大家詳細(xì)介紹了Java的IO流實(shí)現(xiàn)文件和文件夾的復(fù)制,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-06-06
如何將Spring Session存儲(chǔ)到Redis中實(shí)現(xiàn)持久化
這篇文章主要介紹了如何將Spring Session存儲(chǔ)到Redis中實(shí)現(xiàn)持久化,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2023-07-07

