博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
删除list中的特定元素
阅读量:6032 次
发布时间:2019-06-20

本文共 1981 字,大约阅读时间需要 6 分钟。

对于动态删除list中的特定元素,一般用linkedList,删除时有以下两种方法。

1. 循环遍历,找到要删除的元素后删除并且减少list长度。如果不减少list长度,那么就仅仅删除了元素,但没改变循环的判定条件(list.size),就会出现数组越界。

for(int i = 0, len = list.size(); i < len; i++){      if(list.get(i) == 1){         list.remove(i);         len--;       i--;    }  }

2. List接口内部实现了Iterator接口,提供开发者一个iterator()得到当前list对象的一个iterator对象。所以我们还有一个更好的做法是:

LinkedList
list = new LinkedList
(); list.add(4); list.add(2); list.add(1); list.add(1); list.add(2); Iterator
iterator = list.iterator(); while(iterator.hasNext()){ int i = iterator.next(); if(i == 1){ iterator.remove(); } }

结果:

 

分析:

由于LinkedList<Integer> list 的元素对象是Integer,所以我们通过list.iterator()得到的就是Iterator<Integer> iterator。通过循环

      while(iterator.hasNext()){              int i = iterator.next();              if(i == 1){                  iterator.remove();              }          }

看有没有下一个元素,如果有就继续循环,如果没有就跳出循环。在循环里的第一句写

int i = iterator.next();

得到每一个元素对象,因为iterator是Integer对象,所以可以变为int。这里的i就是循环中的得到的对象。

当这个对象的值=1的时候就remove掉。所以原来的list中删除了所有值为1的元素。

        if(i == 1){                  iterator.remove();              }

 原理是:通过list的.iterator()方法可以得到它的迭代器对象,然后我们就可以通过迭代器进行操作了。其实iterator本身就是list,map,set的父类

全部代码:

package com.kale.list;import java.util.Iterator;import java.util.LinkedList;public class Test {        public static void main(String[] args) {        LinkedList
list = new LinkedList
(); list.add(4); list.add(2); list.add(1); list.add(1); list.add(2); Iterator
iterator = list.iterator(); while(iterator.hasNext()){ int i = iterator.next(); if(i == 1){ iterator.remove(); } } for (Integer i:list) { System.out.println("element = " + i); } }}

 

转载地址:http://uebhx.baihongyu.com/

你可能感兴趣的文章
eclipse中默认js编辑器非常慢,尤其在拷贝粘贴代码时的解决方法
查看>>
http Post 请求一网络资源返回字符串
查看>>
window策略设置
查看>>
web 开发之js---js 实现地址栏的表单提交加密编码
查看>>
此类目的是防治序列化Json字符串时的循环引用问题-------最好解决方案
查看>>
八门神器怎么使用
查看>>
HealthKit开发教程之HealthKit的主要类型数据
查看>>
ubuntu 系统网络突然"网络已禁用"
查看>>
linux上很方便的上传下载文件工具rz和sz使用介绍
查看>>
forward内部跳转 和redirect重定向跳转的区别
查看>>
Java——新IO 缓冲区与Buffer
查看>>
Redis常用命令入门2:散列类型
查看>>
构建NCBI本地BLAST数据库 (NR NT等) | blastx/diamond使用方法 | blast构建索引 | makeblastdb...
查看>>
深入理解 JavaScript 异步系列(2)—— jquery的解决方案
查看>>
Cisco配置VLAN+DHCP中继代理+NAT转发上网
查看>>
InfluxDB存储引擎Time Structured Merge Tree——本质上和LSM无异,只是结合了列存储压缩,其中引入fb的float压缩,字串字典压缩等...
查看>>
VC++ 监视文件(夹)
查看>>
【转】keyCode对照表及JS监听组合按键
查看>>
php json_decode无法解析特殊问好字符
查看>>
HBase 常用Shell命令
查看>>