欧美大屁股bbbbxxxx,狼人大香伊蕉国产www亚洲,男ji大巴进入女人的视频小说,男人把ji大巴放进女人免费视频,免费情侣作爱视频

歡迎來到入門教程網(wǎng)!

Java

當前位置:主頁 > 軟件編程 > Java >

Java Collection 移除元素方法及注意事項

來源:本站原創(chuàng)|時間:2020-01-10|欄目:Java|點擊: 次

1. 前言

操作集合是一個 Java 編程人員幾乎每天都在重復的事情。今天我們來研究一下從 Java Collection 中刪除元素的方法。我構(gòu)建了一個簡單的集合,我們以此為例子來展開探索。

 List<String> servers = new ArrayList<>();
 servers.add("Felordcn");
 servers.add("Tomcat");
 servers.add("Jetty");
 servers.add("Undertow");
 servers.add("Resin");

2. for 循環(huán)并不一定能從集合中移除元素

讓我們使用傳統(tǒng)的 foreach 循環(huán)移除 F 開頭的假服務器,但是你會發(fā)現(xiàn)這種操作引發(fā)了 ConcurrentModificationException 異常。

 // 錯誤的示范 千萬不要使用
 for (String server : servers) {
 if (server.startsWith("F")) {
 servers.remove(server);
 }
 }

難道 for 循環(huán)就不能移除元素了嗎?當然不是!我們?nèi)绻艽_定需要被移除的元素的索引還是可以的。

 // 這種方式是可行
 for (int i = 0; i < servers.size(); i++) {
 if (servers.get(i).startsWith("F")) {
 servers.remove(i);
 }
}

但是這種方式我目前只演示了 ArrayList,其它的類型并沒有嚴格測試,留給你自己探索。

3. 迭代器 Iterator 可以刪除集合中的元素

在傳統(tǒng)方式中我們使用 Iterator 是可以保證刪除元素的:

 Iterator<String> iterator = servers.iterator();

 while (iterator.hasNext()) {
  String next = iterator.next();
  if (next.startsWith("F")) {
  iterator.remove();
  }
 }

4. 遍歷刪除元素的缺點

  • 我們需要遍歷集合的每一個元素并對它們進行斷言,哪怕你刪除一個元素。
  • 盡管我們可以通過迭代的方式刪除特定的元素,但是操作繁瑣,根據(jù)集合類型的不同有潛在的 ConcurrentModificationException 異常。
  • 根據(jù)數(shù)據(jù)結(jié)構(gòu)的不同,刪除元素的時間復雜度也大大不同。比如數(shù)組結(jié)構(gòu)的 ArrayList 在刪除元素的速度上不如鏈表結(jié)構(gòu)的 LinkedList。

5. 新的集合元素刪除操作

Java 8 提供了新的集合操作 API 和 Stream 來幫助我們解決這個問題。我在以前的文章中已經(jīng)介紹了 Java 8 Stream API,如果有興趣可以去看看。

5.1 Collection.removeIf()

新的 Collection Api removeIf(Predicate<? super E> filter) 。該 Api 提供了一種更簡潔的使用 Predicate (斷言)刪除元素的方法,于是我們可以更加簡潔的實現(xiàn)開始的需求:

servers.removeIf(s-> s.startsWith("F"));

同時根據(jù)測試,ArrayList 和 LinkedList 的性能接近。一般推薦使用這種方式進行操作。

5.2 Stream 實現(xiàn)移除元素

和上面所有移除操作不同的是,其實任何操作都不會改變 Stream 源,我們僅僅是使用 Stream Api 操作數(shù)據(jù)源的副本。遵循了 數(shù)據(jù)源 -> 中間操作 -> 歸納終止 的生命周期。我們來看看使用 Stream 如何實現(xiàn)我們的意圖。

5.2.1 通過 filter 斷言實現(xiàn)

我們可以使用 Stream 的 filter 斷言。filter 斷言會把符合斷言的流元素匯集成一個新的流,然后歸納起來即可,于是我們可以這么寫:

// 跟以上不同的是 該方式中的斷言是取反的操作。
List<String> newServers = servers.stream().filter(s -> !s.startsWith("F")).collect(Collectors.toList());

這個優(yōu)點上面已經(jīng)說了不會影響原始數(shù)據(jù),生成的是一個副本。缺點就是可能會有內(nèi)存占用問題。

5.2.2 通過 Collectors.partitioningBy 歸納

這種方法雖然可以滿足需要但是我感覺有點投機取巧的成份。Collectors.partitioningBy() 方法本意是做二分類的。該方法會將流中符合斷言的、不符合斷言的元素分別歸納到兩個 key 分別為 true 和 false 的 Map 中,我們可以歸類得到符合和不符合的元素集。實現(xiàn)如下:

Map<Boolean, List<String>> f = servers.stream().collect(Collectors.partitioningBy(s -> !s.startsWith("F")));
 
 List<String> trues = f.get(Boolean.TRUE);
 System.out.println("不以 F 開頭的: " + trues);

 List<String> falses = f.get(Boolean.FALSE);
 System.out.println("以 F 開頭的: " + falses);

一般該方式不推薦在此場景使用,并不符合該 Api 的設計意圖。

6. 總結(jié)

今天我們研究了一些從 Collections 中刪除元素的方法 及其注意事項。希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對我們網(wǎng)站的支持!
如果你覺得本文對你有幫助,歡迎轉(zhuǎn)載,煩請注明出處,謝謝!

上一篇:Java變量常量聲明和定義原理解析

欄    目:Java

下一篇:Java面試題之HashSet的實現(xiàn)原理

本文標題:Java Collection 移除元素方法及注意事項

本文地址:http://mengdiqiu.com.cn/a1/Java/8764.html

網(wǎng)頁制作CMS教程網(wǎng)絡編程軟件編程腳本語言數(shù)據(jù)庫服務器

如果侵犯了您的權(quán)利,請與我們聯(lián)系,我們將在24小時內(nèi)進行處理、任何非本站因素導致的法律后果,本站均不負任何責任。

聯(lián)系QQ:835971066 | 郵箱:835971066#qq.com(#換成@)

Copyright © 2002-2020 腳本教程網(wǎng) 版權(quán)所有