欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

深入了解java.util.Arrays的使用技巧

 更新時(shí)間:2023年02月01日 09:56:34   作者:指北君  
在這篇文章中,我們將來帶大家看看?java.util.Arrays?,我們可以使用?Arrays?創(chuàng)建,比較,排序,搜索,stream?和轉(zhuǎn)化數(shù)組,感興趣的小伙伴可以了解一下

創(chuàng)建

我們來看看,使用Arrays 怎么創(chuàng)建一個(gè)新的數(shù)組,一般來說,我們可以使用Arrays 的 copyOf , copyOfRange 和 fill 方法。

copyOf 和 copyOfRange

要使用copyOfRange,我們需要一個(gè)原始數(shù)組和我們想要復(fù)制的開始索引(包括)和結(jié)束索引(不包括)。 我們先定一個(gè)數(shù)組 intro。

String[]?intro?=?new?String[]?{?"once",?"upon",?"a",?"time"?};
String[]?abridgement?=?Arrays.copyOfRange(storyIntro,?0,?3);?

assertArrayEquals(new?String[]?{?"once",?"upon",?"a"?},?abridgement);?
assertFalse(Arrays.equals(intro,?abridgement));

要使用 copyOf ,,我們需要使用intro和一個(gè)目標(biāo)數(shù)組大小,然后我們會(huì)得到一個(gè)該長度的新數(shù)組。

String[]?revised?=?Arrays.copyOf(intro,?3);
String[]?expanded?=?Arrays.copyOf(intro,?5);

assertArrayEquals(Arrays.copyOfRange(intro,?0,?3),?revised);
assertNull(expanded[4]);

注意,如果我們的目標(biāo)尺寸大于原始尺寸,copyOf會(huì)用 null 填充數(shù)組。

fill

另一種方法,我們可以創(chuàng)建一個(gè)固定長度的數(shù)組,就是填充,當(dāng)我們想要一個(gè)所有元素都相同的數(shù)組時(shí),這個(gè)方法很有用。

String[]?stutter?=?new?String[3];
Arrays.fill(stutter,?"once");

assertTrue(Stream.of(stutter).allMatch(el?->?"once".equals(el));

注意,我們需要事先將數(shù)組實(shí)例化,而不是像String[] filled = Arrays.fill("once", 3);,因?yàn)檫@個(gè)特性是在語言中出現(xiàn)泛型之前引入的。

比較

我們先走來看看 Arrays 的比較方法

equals 和 deepEquals

我們可以使用 equals 進(jìn)行簡單的數(shù)組大小和內(nèi)容比較。 如果我們添加一個(gè)null作為其中一個(gè)元素,內(nèi)容檢查就會(huì)失敗。

assertTrue(Arrays.equals(new?String[]?{?"once",?"upon",?"a",?"time"?},?intro));
assertFalse(Arrays.equals(new?String[]?{?"once",?"upon",?"a",?null?},?intro));

當(dāng)我們有嵌套或多

維數(shù)組時(shí),我們可以使用deepEquals不僅檢查頂層元素,還可以遞歸地執(zhí)行檢查。

Object[]?story?=?new?Object[]?{?intro,?new?String[]?{?"chapter?one",?"chapter?two"?},?end?};
Object[]?copy?=?new?Object[]?{?intro,?new?String[]?{?"chapter?one",?"chapter?two"?},?end?};

assertTrue(Arrays.deepEquals(story,?copy));
assertFalse(Arrays.equals(story,?copy));

注意,這里 deepEquals 是通過的,但equals卻失敗了。這是因?yàn)閐eepEquals在每次遇到數(shù)組時(shí)都會(huì)調(diào)用自己,而equals只是比較子數(shù)組的引用。

hashCode 和 deepHashCode

我們使用hashCode來計(jì)算一個(gè)基于數(shù)組內(nèi)容的整數(shù)

Object[]?looping?=?new?Object[]{?intro,?intro?};?
int?hashBefore?=?Arrays.hashCode(looping);
int?deepHashBefore?=?Arrays.deepHashCode(looping);

現(xiàn)在,我們將原數(shù)組的一個(gè)元素設(shè)置為空,并重新計(jì)算哈希值。

intro[3]?=?null;
int?hashAfter?=?Arrays.hashCode(looping);

deepHashCode檢查嵌套數(shù)組的元素?cái)?shù)量和內(nèi)容是否匹配。 如果我們用deepHashCode重新計(jì)算。

int?deepHashAfter?=?Arrays.deepHashCode(looping);

現(xiàn)在,我們能夠看到這兩個(gè)方法的不同。

assertEquals(hashAfter,?hashBefore);
assertNotEquals(deepHashAfter,?deepHashBefore);

deepHashCode是我們?cè)跀?shù)組上使用HashMap和HashSet等數(shù)據(jù)結(jié)構(gòu)時(shí)使用的基礎(chǔ)計(jì)算。

排序和搜索

排序

如果我們的元素是原始類型,或者它們實(shí)現(xiàn)了 Comparable 接口,我們可以使用sort來執(zhí)行排序。

String[]?sorted?=?Arrays.copyOf(intro,?4);
Arrays.sort(sorted);

assertArrayEquals(new?String[]{?"a",?"once",?"time",?"upon"?},?sorted);

請(qǐng)注意,排序會(huì)使原始引用發(fā)生變化,這就是為什么我們?cè)谶@里進(jìn)行復(fù)制。

排序?qū)?duì)不同的數(shù)組元素類型使用不同的算法。原始類型使用quicksort,對(duì)象類型使用Timsort。對(duì)于一個(gè)隨機(jī)排序的數(shù)組,兩者的平均情況都是O(n log(n))。
從Java 8開始,parallelSort可用于并行排序, 它提供了一種使用幾個(gè)Arrays.sort任務(wù)的并發(fā)排序方法。

搜索

如果我們有一個(gè)排序的數(shù)組,那么我們可以在 O(log n) 中完成,我們可以用 binarySearch 來完成這樣的任務(wù)。

int?exact?=?Arrays.binarySearch(sorted,?"time");
int?caseInsensitive?=?Arrays.binarySearch(sorted,?"TiMe",?String::compareToIgnoreCase);

assertEquals("time",?sorted[exact]);
assertEquals(2,?exact);
assertEquals(exact,?caseInsensitive);

如果我們沒有提供一個(gè)比較器作為第三個(gè)參數(shù),那么 binarySearch 就默認(rèn)我們的元素類型是可比較的。如果我們的數(shù)組沒有被首先排序,那么 binarySearch 將不會(huì)像我們所期望的那樣工作。

我們都知道Arrays在Java 8中進(jìn)行了更新,包含了Stream API的方法,如parallelSort、stream和setAll等。

stream 使我們能夠完全訪問我們的數(shù)組的Stream API。

Assert.assertEquals(Arrays.stream(intro).count(),?4);

exception.expect(ArrayIndexOutOfBoundsException.class);
Arrays.stream(intro,?2,?1).count();

我們可以為流提供包容性和排他性指數(shù),但是如果指數(shù)失序、為負(fù)數(shù)或超出范圍,我們應(yīng)該判斷 ArrayIndexOutOfBoundsException。

轉(zhuǎn)化

toString、asList和setAll給了我們幾種不同的方法來轉(zhuǎn)換數(shù)組。

toString和deepToString

我們可以通過toString獲得原始數(shù)組的可讀版本的一個(gè)好方法。

assertEquals("[once,?upon,?a,?time]",?Arrays.toString(storyIntro));

當(dāng)數(shù)組有嵌套的時(shí)候,我們必須再次使用deepToString 來打印嵌套數(shù)組的內(nèi)容。

assertEquals(
????"[[once,?upon,?a,?time],?[chapter?one,?chapter?two],?[the,?end]]",
????Arrays.deepToString(story));

asList

在所有的數(shù)組方法中,最方便我們使用的是asList。我們有一個(gè)簡單的方法把數(shù)組變成一個(gè)列表。

List<String>?rets?=?Arrays.asList(storyIntro);

assertTrue(rets.contains("upon"));
assertTrue(rets.contains("time"));
assertEquals(rets.size(),?4);

返回的列表將是一個(gè)固定的長度,而且無法添加或刪除元素,還要注意的是,asList會(huì)返回這個(gè)ArrayList的類型,和我們平常在使用的ArrayList 并不一樣。在調(diào)試的時(shí)候,就可能是非常具有欺騙性的,我們?cè)趯懙倪^程中特別要注意。

setAll

通過setAll,我們可以用一個(gè) functional interface 來設(shè)置一個(gè)數(shù)組的所有元素。下面的代碼現(xiàn)將位置索引作為一個(gè)參數(shù)傳入到getWord方法中。

String[]?longAgo?=?new?String[4];
Arrays.setAll(longAgo,?i?->?this.getWord(i));?
assertArrayEquals(longAgo,?new?String[]{"a","long","time","ago"});

當(dāng)然,異常處理是使用lambda的一個(gè)比較棘手的部分。所以請(qǐng)記住,如果lambda拋出一個(gè)異常,那么Java就不會(huì)定義數(shù)組的最終狀態(tài)。

到此這篇關(guān)于深入了解java.util.Arrays的使用技巧的文章就介紹到這了,更多相關(guān)java.util.Arrays使用技巧內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • springBoot啟動(dòng)輸出三行日志控制臺(tái)自動(dòng)停止操作

    springBoot啟動(dòng)輸出三行日志控制臺(tái)自動(dòng)停止操作

    這篇文章主要介紹了springBoot啟動(dòng)輸出三行日志控制臺(tái)自動(dòng)停止操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2021-08-08
  • Spring中Bean掃描原理詳情

    Spring中Bean掃描原理詳情

    這篇文章主要介紹了Spring中Bean掃描原理詳情,文章為榮啊主題展開詳細(xì)的內(nèi)容介紹,具有一定的參考價(jià)值,需要的小伙伴可以參考一下
    2022-07-07
  • 使用Springboot實(shí)現(xiàn)OAuth服務(wù)的示例詳解

    使用Springboot實(shí)現(xiàn)OAuth服務(wù)的示例詳解

    OAuth(Open Authorization)是一個(gè)開放標(biāo)準(zhǔn),用于授權(quán)第三方應(yīng)用程序訪問用戶資源,而不需要共享用戶憑證。本文主要介紹了如何使用Springboot實(shí)現(xiàn)一個(gè)OAuth服務(wù),需要的可以參考一下
    2023-05-05
  • feign post參數(shù)對(duì)象不加@RequestBody的使用說明

    feign post參數(shù)對(duì)象不加@RequestBody的使用說明

    這篇文章主要介紹了feign post參數(shù)對(duì)象不加@RequestBody的使用說明,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2021-10-10
  • SpringMVC RESTful支持實(shí)現(xiàn)過程演示

    SpringMVC RESTful支持實(shí)現(xiàn)過程演示

    這篇文章主要介紹了SpringMVC RESTful支持實(shí)現(xiàn)過程演示,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2019-11-11
  • Java中使用WebSocket的幾種方式

    Java中使用WebSocket的幾種方式

    本文主要介紹了Java中使用WebSocket的幾種方式
    2024-06-06
  • Spring中@PostConstruct的實(shí)現(xiàn)方法

    Spring中@PostConstruct的實(shí)現(xiàn)方法

    大多數(shù)java程序員都使用過@PostConstruct注解,它的作用就是在Bean初始化完成后執(zhí)行,相當(dāng)于我們常說的init()方法,但是我們看@PostConstruct只有單單的一個(gè)注解,它到底是如何實(shí)現(xiàn)在Bean初始化完成后就被調(diào)用的呢,本文將詳細(xì)給大家介紹一下
    2023-06-06
  • java編程約瑟夫問題實(shí)例分析

    java編程約瑟夫問題實(shí)例分析

    這篇文章主要介紹了java編程約瑟夫問題實(shí)例分析,具有一定借鑒價(jià)值,需要的朋友可以參考下。
    2017-12-12
  • 簡單理解java泛型的本質(zhì)(非類型擦除)

    簡單理解java泛型的本質(zhì)(非類型擦除)

    泛型在java中有很重要的地位,在面向?qū)ο缶幊碳案鞣N設(shè)計(jì)模式中有非常廣泛的應(yīng)用。泛型是參數(shù)化類型的應(yīng)用,操作的數(shù)據(jù)類型不限定于特定類型,可以根據(jù)實(shí)際需要設(shè)置不同的數(shù)據(jù)類型,以實(shí)現(xiàn)代碼復(fù)用。下面小編來簡單講一講泛型
    2019-05-05
  • Java8 日期和時(shí)間類的基本使用

    Java8 日期和時(shí)間類的基本使用

    這篇文章主要介紹了Java 日期和時(shí)間類的基本使用,幫助大家更好的理解和學(xué)習(xí)Java,感興趣的朋友可以了解下
    2020-08-08

最新評(píng)論