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é)尾
如果覺得對(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-07Java使用動(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-04java多線程編程之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-01Java的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