在线观看www成人影院-在线观看www日本免费网站-在线观看www视频-在线观看操-欧美18在线-欧美1级

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

Arrays的copyOf,copyOfRange和fill方法

科技綠洲 ? 來源:了不起 ? 作者:了不起 ? 2023-09-25 14:12 ? 次閱讀

在本文中,我們來看看 java.util.Arrays ,我們可以使用 Arrays 創建,比較,排序,搜索,stream 和轉化數組。

創建

我們來看看,使用Arrays 怎么創建一個新的數組,一般來說,我們可以使用Arrays 的 copyOf , copyOfRange 和 fill 方法。

copyOf 和 copyOfRange

要使用copyOfRange,我們需要一個原始數組和我們想要復制的開始索引(包括)和結束索引(不包括)。 我們先定一個數組 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和一個目標數組大小,然后我們會得到一個該長度的新數組。

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

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

注意,如果我們的目標尺寸大于原始尺寸,copyOf會用 null 填充數組。

fill

另一種方法,我們可以創建一個固定長度的數組,就是填充,當我們想要一個所有元素都相同的數組時,這個方法很有用。

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

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

注意,我們需要事先將數組實例化,而不是像String[] filled = Arrays.fill("once", 3);,因為這個特性是在語言中出現泛型之前引入的。

比較

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

equals 和 deepEquals

我們可以使用 equals 進行簡單的數組大小和內容比較。 如果我們添加一個null作為其中一個元素,內容檢查就會失敗。

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

當我們有嵌套或多維數組時,我們可以使用deepEquals不僅檢查頂層元素,還可以遞歸地執行檢查。

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卻失敗了。這是因為deepEquals在每次遇到數組時都會調用自己,而equals只是比較子數組的引用。

hashCode 和 deepHashCode

我們使用hashCode來計算一個基于數組內容的整數

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

現在,我們將原數組的一個元素設置為空,并重新計算哈希值。

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

deepHashCode檢查嵌套數組的元素數量和內容是否匹配。 如果我們用deepHashCode重新計算。

int deepHashAfter = Arrays.deepHashCode(looping);

現在,我們能夠看到這兩個方法的不同。

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

deepHashCode是我們在數組上使用HashMap和HashSet等數據結構時使用的基礎計算。

排序和搜索

排序

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

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

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

請注意,排序會使原始引用發生變化,這就是為什么我們在這里進行復制。
排序將對不同的數組元素類型使用不同的算法。原始類型使用quicksort,對象類型使用Timsort。對于一個隨機排序的數組,兩者的平均情況都是O(n log(n))。
從Java 8開始,parallelSort可用于并行排序, 它提供了一種使用幾個Arrays.sort任務的并發排序方法。

搜索

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

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

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

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

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

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

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

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

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

轉化

toString、asList和setAll給了我們幾種不同的方法來轉換數組。

toString和deepToString

我們可以通過toString獲得原始數組的可讀版本的一個好方法。

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

當數組有嵌套的時候,我們必須再次使用deepToString 來打印嵌套數組的內容。

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

asList

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

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

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

返回的列表將是一個固定的長度,而且無法添加或刪除元素,還要注意的是,asList會返回這個ArrayList的類型,和我們平常在使用的ArrayList 并不一樣。在調試的時候,就可能是非常具有欺騙性的,我們在寫的過程中特別要注意。

setAll

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

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

當然,異常處理是使用lambda的一個比較棘手的部分。所以請記住,如果lambda拋出一個異常,那么Java就不會定義數組的最終狀態。

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • 數據結構
    +關注

    關注

    3

    文章

    573

    瀏覽量

    40154
  • 數組
    +關注

    關注

    1

    文章

    417

    瀏覽量

    25978
  • Arrays
    +關注

    關注

    0

    文章

    6

    瀏覽量

    6422
  • Fill
    +關注

    關注

    0

    文章

    4

    瀏覽量

    2892
收藏 人收藏

    評論

    相關推薦

    Characterizing and Modeling the Impact of Power/Ground Via Arrays on Power Pl

    Characterizing and Modeling the Impact of Power/Ground Via Arrays on Power Plane
    發表于 07-01 18:03

    Altium中Fill,Polygon Pour,Plane的區別和用法

    `Fill表示繪制一塊實心的銅皮,將區域中的所有連線和過孔連接在一塊,而不考慮是否屬于同一個網絡。假如所繪制的區域中有VCC和GND兩個網絡,用Fill命令會把這兩個網絡的元素連接在一起,這樣就有
    發表于 01-15 19:33

    AD中關于Fill,Polygon_Pour,Plane的區別和用法

    在 AD 中,大面積覆銅有 3 個重要概念:Fill填充Polygon Pour(灌銅)Plane(平面層)這 3 個概念對應 3 種的大面積覆銅的方法,下面我將對其做詳細介紹:一.FillFill
    發表于 08-28 14:30

    填充FILL ,原理圖導網絡到PCB,FILL沒網絡的處理方法分享!

    問:我在封裝的焊盤上填充了一個FILL原理圖導網絡到PCB,這個FILL沒網絡;只有焊盤有網絡;有什么方法可以解決嗎答:異形焊盤確實是這樣的,解決辦法就是Ctrl+H然后給他賦予網絡就可以了,快捷鍵是選中物理連接
    發表于 09-11 03:02

    低電容TVS ESD ARRAYS保護器件

    時,一些*敏感的組件可能被低至20V以下的ESD電壓損壞,過去所采用的傳統保護方法,如火花放電器、齊納二極管、RC網絡和箝位二極管已經不能滿足。      TVS ESD ARRAYS系列低電壓低電容
    發表于 03-26 13:16

    fill_n的主要作用是什么

    fill_n的主要作用是什么?fill_n指令包含哪幾個?
    發表于 09-30 09:15

    THAT300series Matched Transistor Arrays

    Array ICS作為 專業級的低噪音,高性能匹配陣列晶體管ICS。低噪音:0.75nV/√HZ 高速度:fT =350MHZ。可以很好的兼容ADI和TI的相關Matched Transistor Arrays/Matched Monolithic Transistor Arra
    發表于 04-26 11:29

    Allegro Fill鋪銅教程

    Allegro Fill鋪銅教程 如下我們將以四層印制板為例來進行講解! 1.點擊顏色按鈕 ,在顏色設置的“Geometry”欄中設置PCB邊框線顏色
    發表于 03-21 19:02 ?1.1w次閱讀
    Allegro <b class='flag-5'>Fill</b>鋪銅教程

    AD中關于Fill

    在AD中,大面積覆銅有3個重要概念: Fill(銅皮)3 Polygon Pour(灌銅) Plane(平面層)3 這3個概念對應3種的大面積覆銅的方法,對于剛接觸AD的用戶來說,很難區分。
    發表于 09-12 16:13 ?0次下載

    Digital Signal Processing with Field Programmable Gate Arrays

    FPGA,數字信號處理:Digital Signal Processing with Field Programmable Gate Arrays
    發表于 12-17 11:58 ?51次下載

    Java數組的常用方法_Java:數組工具類Arrays類的常用方法的用法及代碼

    本文主要詳細介紹了Java數組的常用方法以及數組工具類Arrays類的常用方法的用法及代碼。
    發表于 01-29 10:25 ?2927次閱讀

    S7-1200填充塊指令(U)FILL_BLK使用說明

    (U)FILL_BLK指令是當EN條件滿足時,實現用輸入變量批量填充輸出區域的功能。
    的頭像 發表于 01-13 10:33 ?3360次閱讀

    Java中Arrays類是什么 Arrays常用方法

    了解Arrays類的概念 **A****rrays** 位于java.util包下,Arrays是一個操作數組的工具類。 Arrays常用方法
    的頭像 發表于 02-17 15:11 ?1061次閱讀
    Java中<b class='flag-5'>Arrays</b>類是什么 <b class='flag-5'>Arrays</b>常用<b class='flag-5'>方法</b>

    怎樣運用Java實現冒泡排序和Arrays排序出來

    在數據結構中我們學習了解了冒泡排序和Arrays排序的基本算法,但沒能夠用編程語言實現出來。那我們應該怎樣運用Java通過編程語言將冒泡排序和Arrays排序實現出來呢?
    的頭像 發表于 03-02 09:37 ?518次閱讀
    怎樣運用Java實現冒泡排序和<b class='flag-5'>Arrays</b>排序出來

    JDK中java.lang.Arrays 類的源碼解析

    揭開它神秘的面紗。 java.util.Arrays 類是 JDK 提供的一個工具類,用來處理數組的各種方法,而且每個方法基本上都是靜態方法,能直接通過類名
    的頭像 發表于 10-11 15:31 ?627次閱讀
    JDK中java.lang.<b class='flag-5'>Arrays</b> 類的源碼解析
    主站蜘蛛池模板: 免费看欧美一级特黄α大片| 精品在线一区二区三区| 四虎黄色网| 成年美女黄网站色大免费视频 | 亚洲伊人99综合网| 日韩综合nv一区二区在线观看| 国产欧美一级片| 欧美性极品hd高清视频| 91大神精品全国在线观看| 亚洲一区二区三区免费观看| 美女视频一区二区三区在线| 亚洲激情四射| 1024人成软件色www| 99精品视频在线播放2| 免费观看激色视频网站bd| 亚洲91色| 亚洲欧美日韩国产一区二区三区精品 | 四虎在线免费视频| 日韩毛片高清在线看| 欧美午夜色视频国产精品| 久久青草精品免费资源站| 欧美高清在线观看视频| 精品美女在线| 亚洲第一成人在线| 亚洲人成网站999久久久综合| 天天操天天擦| 美国一区二区三区| 国产精品一区在线播放| 国产成人精品日本亚洲语音1| 香蕉视频色版在线观看| 免费网站成人亚洲| 免费公开视频人人人人人人人| 国产精品特黄毛片| 国内外精品免费视频| 永久观看| 视频免费在线| 色网站观看| 亚洲天堂社区| 久久久久综合| 天天舔天天射天天干| 窝窝午夜在线观看免费观看|