成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

詳解 Java.util.Arrays 的使用技巧

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

大家好,我是指北君。

在本文中,我們來看看 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就不會定義數組的最終狀態。

責任編輯:武曉燕 來源: Java技術指北
相關推薦

2009-09-04 10:45:18

MyEclipse使用

2023-02-03 08:21:55

2009-12-04 10:19:11

PHP hack

2009-08-17 08:42:48

LinuxScreen命令使用技巧

2022-12-22 07:40:28

2009-12-07 10:54:46

PHP uploade

2009-07-31 17:51:42

linux vi命令詳linux vi命令編輯器

2022-12-23 07:36:50

RedisLettuce技巧

2022-12-27 07:39:28

RedisRedissonLettuce

2021-09-29 06:03:37

JavaScriptreduce() 前端

2023-10-31 08:22:31

線程類型.NET

2023-11-27 13:53:00

Java數據轉換

2023-09-25 13:19:41

pandasPython

2011-04-01 10:53:43

2011-01-19 14:39:59

Qmail技巧

2011-01-21 14:30:02

Thunderbird技巧

2017-08-04 17:07:32

JavaArraysList

2009-12-10 13:27:23

GNOME桌面

2016-09-18 16:58:09

JavaProperties

2019-09-12 08:03:56

MySQL索引數據庫
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 免费亚洲成人 | av激情在线 | 亚洲欧美国产一区二区三区 | 操久久 | 中文字幕一二三区 | 国产精品国产成人国产三级 | 国产精品自拍视频 | 超碰日本 | 亚洲深夜福利 | 亚洲视频免费观看 | 久久精品国产一区二区电影 | 精品亚洲一区二区 | 91影院在线观看 | 福利国产| www.av在线 | 在线免费国产视频 | 亚洲久草| 岛国毛片 | 美女国产一区 | 粉嫩一区二区三区四区公司1 | 免费观看一级毛片 | 欧美天堂在线 | 九九九久久国产免费 | 欧美一区2区三区4区公司 | 狠狠躁躁夜夜躁波多野结依 | 午夜电影网| 日韩精品一区二区三区中文在线 | 日韩精品a在线观看图片 | 超碰97在线免费 | 国精久久| 男女羞羞视频在线免费观看 | 夜夜摸天天操 | 欧美亚洲在线 | 少妇午夜一级艳片欧美精品 | 中文字幕免费观看 | 亚洲a视频 | 欧美日韩综合视频 | 久久久久久艹 | 国产精品高潮呻吟久久久久 | 亚洲欧美综合精品久久成人 | 少妇诱惑av |