java集合类遍历删除方法测试以及使用场景记录
package test0; import java.util.List;
import java.util.Map;
import java.util.Map.Entry;
import java.util.Set;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.HashSet;
import java.util.Iterator;
import java.util.LinkedList; /**
* 测试集合类遍历删除方法
* 目前是基本的遍历方式,没有包含java8里面的遍历方式
*/
public class Test2 { public static void main(String[] args) {
forEach();
operateList();
operateSet();
operateMap(); } /**
* JDK1.5中,应用新特性For-Each循环,通用遍历读取所有集合类的方法,但是不能删除,
* For-Each语法最终被编译器转为了对Iterator.next()的调用,所以应该和Iterator性能差不多
* 现在测试到数据量很大的时候,比如上千万数据时,性能差距才会出来
* 如果在遍历是修改集合类,将会抛出java.util.ConcurrentModificationException异常
* 例如:
* Exception in thread "main" java.util.ConcurrentModificationException
* at java.util.ArrayList$Itr.checkForComodification(Unknown Source)
*at java.util.ArrayList$Itr.next(Unknown Source)
*at Test.main(Test.java:12)
*/
public static void forEach() {
// list
ArrayList<Integer> arr = new ArrayList<Integer>();
arr.add(1);
arr.add(2);
for (Integer i : arr) {
System.out.println("for each list: " + i);
} // set
HashSet<Integer> hs = new HashSet<Integer>();
hs.add(3);
hs.add(4);
for (Integer i : hs) {
System.out.println("for each set: " + i);
} // map
HashMap<Integer, Integer> hm = new HashMap<Integer, Integer>();
hm.put(5, 5);
hm.put(6, 6);
for (Entry<Integer, Integer> entry : hm.entrySet()) {
System.out.println("for each map: <" + entry.getKey() + "," + entry.getValue() + ">");
} } /*
list接口复杂度
| Arraylist | LinkedList
------------------------------------------
get(index) | O(1) | O(n)
add(E) | O(n) | O(1)
add(E, index) | O(n) | O(n)
remove(index) | O(n) | O(n)
Iterator.remove() | O(n) | O(1)
Iterator.add(E) | O(n) | O(1) */ /**
* 操作list
* LinkedList 是链表形式,使用于 遍历list并删除元素方法2 效率更高
* ArrayList 是数组形式,两种方法差不了多少
*
*/
public static void operateList() {
final int size = 10;
List<Integer> list = new ArrayList<Integer>();
for (int i = 0; i < size; i++) {
list.add(3);
} // 遍历list并删除元素方法1
for (int i = list.size() - 1; i >= 0; i--) {
if (list.get(i) == 3) {
list.remove(i);
}
} for (int i = 0; i < size; i++) {
list.add(3);
} // 遍历list并删除元素方法2
for (Iterator<Integer> it = list.iterator(); it.hasNext();) {
Integer e = it.next();
if (e.equals(3)) {
it.remove();
}
}
} /**
* 操作集合
*/
public static void operateSet() {
final int size = 10;
Set<Integer> set = new HashSet<Integer>();
for (int i = 0; i < size; i++) {
set.add(i);
} // 遍历set并删除元素方法
for (Iterator<Integer> it = set.iterator(); it.hasNext();) {
Integer e = it.next();
if (e.equals(3) || e.equals(4)) {
it.remove();
}
}
} /**
* 操作map,根据需求选择遍历方法,少量数据时不好对比性能出差距,需要上百万数据才容易比较出效果
* 1.entrySet遍历法:key value都需要时:key value都一直需要取出来时使用性能更高
* 2. keySet遍历法:key value都需要时:主要使用key,少量使用value时使用性能更高
* 3.values遍历value,这个没有得到key,但是也是可以删除的:主要使用value时使用
*
* 注意:
* 由于HashMap使用hash算法存储,所以时间复杂度为O(1),
* 而TreeMap使用红黑树存储,时间复杂度为O(logN),
* 所以假如一直需要key value的话,TreeMap使用entrySet遍历法效率将更高,而HashMap性能区别没有那么明显
*/
public static void operateMap() {
final int size = 10;
Map<Integer, Integer> map = new HashMap<Integer, Integer>();
for (int i = 0; i < size; i++) {
map.put(i, i);
} // 1.entrySet遍历法
for (Iterator<Entry<Integer, Integer>> it = map.entrySet().iterator(); it.hasNext();) {
Entry<Integer, Integer> e = it.next();
Integer key = e.getKey();
Integer value = e.getValue();
if (key.equals(3) || key.equals(4)) {
it.remove();
}
} // 2. keySet遍历法
for (Iterator<Integer> it = map.keySet().iterator(); it.hasNext();) {
Integer key = it.next();
if (key.equals(5) || key.equals(6)) {
// Integer value = map.get(key);
it.remove();
}
} // 3.values遍历value,这个没有得到key,但是也是可以删除的
for (Iterator<Integer> it = map.values().iterator(); it.hasNext();) {
Integer value = it.next();
if (value.equals(7) || value.equals(8)) {
// Integer value = map.get(key);
it.remove();
}
}
System.out.println("operateMap: " + map);
} }
java集合类遍历删除方法测试以及使用场景记录的更多相关文章
- java数组遍历 删除remove
package com.b; import java.util.ArrayList; //数组遍历删除,添加 public class Core2 { private String name; pri ...
- java List遍历的方法
List可以用序号来遍历,但通常推荐使用iterator来遍历Iterator itr = list.iterator();while (itr.hasNext()) { Object nextObj ...
- Java Hashtable遍历与方法使用
参考文档 我参考了Java 集合系列11之 Hashtable详细介绍(源码解析)和使用示例,阅读了jdk 1.8的源码 Hashtable的继承关系 Hashtable继承了Dictionary类, ...
- java集合遍历删除指定元素异常分析总结
在使用集合的过程中,我们经常会有遍历集合元素,删除指定的元素的需求,而对于这种需求我们往往使用会犯些小错误,导致程序抛异常或者与预期结果不对,本人很早之前就遇到过这个坑,当时没注意总结,结果前段时间又 ...
- Java 循环遍历删除set list中的元素
删除List和Set中的某些元素 错误代码的写法: Set<String> set = new HashSet<String>(); set.add("aaaaaa& ...
- java 数组遍历(方法内部的代码)
//数组遍历(依次输出数组中的每一个元素)二维数组: int[][] arr={{1,2},{3,4,5},{6,7}}; for(int i=0;i<arr.length;i++){ for( ...
- 对JAVA集合进行遍历删除时务必要用迭代器
java集合遍历删除的方法: 1.当然这种情况也是容易解决,实现方式就是讲遍历与移除操作分离,即在遍历的过程中,将需要移除的数据存放在另外一个集合当中,遍历结束之后,统一移除. 2.使用Iterato ...
- Java动态 遍历List 时删除List特征元素 异常问题 及解决方案总结
首先.这是一个极其简单的问题,大牛可忽略.新手可能会遇到,Java中遍历某个List 时删除该List元素 会抛出异常. 这一个简单的问题再高手严重不值一提,但新手可能会比較困惑,用哪种方式能够安全有 ...
- Java中遍历Map集合的四种方法
在Java中如何遍历Map对象 How to Iterate Over a Map in Java 在java中遍历Map有不少的方法.我们看一下最常用的方法及其优缺点. 既然java中的所有map都 ...
随机推荐
- SqlServer判断数据库、表、存储过程、函数是否存在
假设场景是: 需要给一个脚本给客户更新, 这个对象可能存在或不存在 -- 更新存储过程 USE [数据库名] GO SET ANSI_NULLS ON GO SET QUOTED_IDENTIFIER ...
- PHP学习笔记一
<html> <head> <title></title> <meta http-equiv="content-type" c ...
- [转]用apache反向代理解决单外网ip对应内网多个web主机的问题
用apache反向代理解决单外网ip对应内网多个web主机的问题 转载一个有独立外网IP,需内网服务器对外发布的例子,是应用apache虚拟主机的. 来源地址:http://www.itshantou ...
- UVA 11214 Guarding the Chessboard
题意: 皇后防御的范围是他所在横.竖.对角线,地图上的#为可以放旗子的地方.问最少放几个皇后能防守所有#. 分析: vis数组开4维,对应行.列.主对角线.副对角线 代码: #include < ...
- Java路径问题最终解决方案—可定位所有资源的相对路径寻址
1.在Java项目中,应该通过绝对路径访问文件,以下为访问的常用方法: 第一种方法:类名.class.getResource("/").getPath()+文件名 第二种方法:Th ...
- 接口(三)——JAVA的多重继承
一.接口的作用 ①.为了能够向上转型为多个基类型 ②.防止客户端程序员创建该类的对象——同抽象类 二.通过继承扩展接口 interface Monster{ void menace(); } inte ...
- 编译安装mysql5.7.9
第一步:安装一些可能会用到的依赖 yum -y install gcc-c++ ncurses-devel cmake make perl gcc autoconf automake zlib lib ...
- USB OTG介绍(转载)
1. 概要 OTG设备使用插头中的ID引脚来区分A/B Device,ID接地被称作为A-Device,为连接时候的USB Host,A-Device始终为总线提供电力,ID悬空被称作为B-Devic ...
- 解决C/C++程序执行一闪而过的方法(三种办法)
简述 在VS编写控制台程序的时候,包括使用其他IDE(Visual C++)编写C/C++程序,经常会看到程序的执行结果一闪而过,要解决这个问题,可以在代码的最后加上system(“pause”).g ...
- idea编译工程时出现Error:java: 无效的目标发行版: 1.8
见图,从上述可以看出工程用的jdk1.7,而idea编译时采用的是1.8版本(应该idea新版本内置的jre是1.8吧,默认编译采用1.8) 修改:如下图 http://blog.csdn.ne ...