帮一个网友解答问题时,发现这样一个易错知识点,现总结如下:

1、易错点:

ArrayList移除元素后,剩下的元素会立即重排,他的 size() 也会立即减小,在循环过程中容易出错。(拓展:延伸到所有的集合是否可行)

2、易错点分析:

在for循环遍历ArrayList时,在循环中移除元素后,集合的size()会立即减1

剩下的元素也会重新排列,被移除元素后面元素的下标会发生变化,即后面的元素小标会减1

此时在for循环中的第二个参数 i < list.size() 就不是原来集合的大小了,而是比上一次循环小1

而循环变量 i 的值还是正常递增

如果继续遍历集合,就容易漏掉某个元素

3、实例分析:

此实例的目的是:去除集合中带有#字符的url

(1)错误版本:

<span style="font-family:KaiTi_GB2312;font-size:18px;">import java.util.ArrayList;

public class GouLv {
public static void main(String[] args) throws Exception {
ArrayList<String> urls = new ArrayList<String>();
urls.add("http://www.baidu.com");
urls.add("http:/#/www.baidu.com");
urls.add("http://www#.zxitb.com");
urls.add("http://www.zxitb.com"); int index;
for (int i = 0; i < urls.size(); i++) {
index = -1;
String url = urls.get(i);
index = url.indexOf('#');
if(index != -1){
urls.remove(url);
}else {
System.out.println(url);
}
} for (int i = 0; i < urls.size(); i++) {
System.out.println("去除#后的url : " + urls.get(i));
}
}
} -----------------------------------------------
输出结果为:
http://www.baidu.com
http://www.zxitb.com
去除#后的url : http://www.baidu.com
去除#后的url : http://www#.zxitb.com
去除#后的url : http://www.zxitb.com ------------------------------------------------
拓展:
如果map中的元素这样放
urls.add("http://www.baidu.com");
urls.add("http:/#/www.baidu.com");
urls.add("http://www.zxitb.com");
urls.add("http://www#.zxitb.com");
那结果为
http://www.baidu.com
http://www.zxitb.com
去除#后的url : http://www.baidu.com
去除#后的url : http://www.zxitb.com
感觉上时达到了目的,其实不然</span>

(2)错误分析版本:

<span style="font-family:KaiTi_GB2312;font-size:18px;">import java.util.ArrayList;

public class GouLv {
public static void main(String[] args) throws Exception {
ArrayList<String> urls = new ArrayList<String>();
urls.add("http://www.baidu.com");
urls.add("http:/#/www.baidu.com");
urls.add("http://www#.zxitb.com");
urls.add("http://www.zxitb.com"); int index;
for (int i = 0; i < urls.size(); i++) {
index = -1;
System.out.println("循环次数===========" + (i+1));
String url = urls.get(i);
index = url.indexOf('#');
if(index != -1){
System.out.println("有#的url: " + url);
urls.remove(url); System.out.println("移除元素后urls的size: " + urls.size());
for(int j = 0; j < urls.size(); j++){ //移除元素后打印urls中的元素
System.out.println("移除元素后urls中下标为【 " + j + " 】的元素" + urls.get(j));
}
}else {
System.out.println("没有#的url: " + url);
} System.out.println("urls的大小: " + urls.size() + "=====下一次循环i的值将会为: " + (i+1));
} for (int i = 0; i < urls.size(); i++) { //打印最终结果
System.out.println("去除#后的url : " + urls.get(i));
}
} } ------------------------------------------------------------
结果:
循环次数===========1
没有#的url: http://www.baidu.com
urls的大小: 4=====下一次循环i的值将会为: 1
循环次数===========2
有#的url: http:/#/www.baidu.com
移除元素后urls的size: 3
移除元素后urls中下标为【 0 】的元素http://www.baidu.com
移除元素后urls中下标为【 1 】的元素http://www#.zxitb.com
移除元素后urls中下标为【 2 】的元素http://www.zxitb.com
urls的大小: 3=====下一次循环i的值将会为: 2
循环次数===========3
没有#的url: http://www.zxitb.com
urls的大小: 3=====下一次循环i的值将会为: 3
去除#后的url : http://www.baidu.com
去除#后的url : http://www#.zxitb.com
去除#后的url : http://www.zxitb.com</span>

分析:

此时第一次循环的是http://www.baidu.com,第二次循环的是http:/#/www.baidu.com

由于第二次循环移除了元素,所以size()减1就是3,剩下的元素也重新排列。而此时 i 为2,就是循环的新集合中的http://www.zxitb.com(第三次循环)

此时符合条件,循环结束

跳过了http://www#.zxitb.com的循环

更改思路:

移除元素后,修改循环中的第二个参数或者第三个参数。此时我在移除元素后把循环变量 i 的值减1

(3)正确版本:

<span style="font-family:KaiTi_GB2312;font-size:18px;">import java.util.ArrayList;

public class GouLv {
public static void main(String[] args) throws Exception {
ArrayList<String> urls = new ArrayList<String>();
urls.add("http://www.baidu.com");
urls.add("http:/#/www.baidu.com");
urls.add("http://www#.zxitb.com");
urls.add("http://www.zxitb.com"); int index;
for (int i = 0; i < urls.size(); i++) {
index = -1;
String url = urls.get(i);
index = url.indexOf('#');
if(index != -1){
System.out.println("有#的url: " + url);
urls.remove(url);
i-- ;
}else {
System.out.println("没有#的url: " + url);
}
} for (int i = 0; i < urls.size(); i++) { //打印最终结果
System.out.println("去除#后的url : " + urls.get(i));
}
} } ---------------------------------------------------------
结果:
没有#的url: http://www.baidu.com
有#的url: http:/#/www.baidu.com
有#的url: http://www#.zxitb.com
没有#的url: http://www.zxitb.com
去除#后的url : http://www.baidu.com
去除#后的url : http://www.zxitb.com</span>

OK ! 问题解决!

Java易错知识点(1) - 关于ArrayList移除元素后剩下的元素会立即重排的更多相关文章

  1. Java易错知识点(2) - 在读取Cookie时除了Key,Value是得不到其他信息的

    全文总结: 在读取Cookie,然后操作时,除了getName(),getValue()外,不要妄图得到其他信息,如下方法不会得到值的: cookie.getMaxAge(); cookie.getD ...

  2. JavaScript易错知识点整理

    前言 本文是我学习JavaScript过程中收集与整理的一些易错知识点,将分别从变量作用域,类型比较,this指向,函数参数,闭包问题及对象拷贝与赋值这6个方面进行由浅入深的介绍和讲解,其中也涉及了一 ...

  3. JavaScript 易错知识点整理

    本文是我学习JavaScript过程中收集与整理的一些易错知识点,将分别从变量作用域,类型比较,this指向,函数参数,闭包问题及对象拷贝与赋值这6个方面进行由浅入深的介绍和讲解,其中也涉及了一些ES ...

  4. JavaScript易错知识点整理[转]

    前言 本文是我学习JavaScript过程中收集与整理的一些易错知识点,将分别从变量作用域,类型比较,this指向,函数参数,闭包问题及对象拷贝与赋值这6个方面进行由浅入深的介绍和讲解,其中也涉及了一 ...

  5. JS易错知识点

    JAVASCRIPT易错知识点整理 前言 本文是学习JavaScript过程中收集与整理的一些易错知识点,将分别从变量作用域,类型比较,this指向,函数参数,闭包问题及对象拷贝与赋值这6个方面进行由 ...

  6. 【笔试题】Java 易错题精选

    笔试题 Java 易错题精选 1.写出下列程序的运行结果( )String 不变性Java 值传递 public class Test { public static void main(String ...

  7. JavaScript易错知识点

    JavaScript易错知识点整理1.变量作用域上方的函数作用域中声明并赋值了a,且在console之上,所以遵循就近原则输出a等于2. 上方的函数作用域中虽然声明并赋值了a,但位于console之下 ...

  8. java易错基础知识点

    一. Switch 1.其能接受的数据类型有四个,char , byte, short, int2.Default 可放在switch中的任何一个地方,但只有给定的条件匹配不到时,才会执行3.Case ...

  9. [置顶] 单片机C语言易错知识点经验笔记

    今天写这一篇文章并不是因为已经想好了一篇文章才写下来,而是我要将这一篇文章作为一个长期的笔记来写,我会一直更新.在进行单片机开发时,经常都会出现一些很不起眼的问题,这些问题其实都是很基础的c语言知识点 ...

随机推荐

  1. 在阿里云上遇见更好的Oracle(一)

    2003年毕业那年正好遇上非典,好不容易找到一份制造工厂的工作,凭着一点点的SQL基础进入了IT部门,在那里第一次听说了Oracle.在此之前,我对数据库的认知基本还停留在Access阶段,耳闻过一点 ...

  2. LLLYYY的数字思维(模拟题)

    链接:https://ac.nowcoder.com/acm/contest/318/G LLLYYY很喜欢写暴力模拟贪心思维.某一天在机房,他突然抛给了队友ppq一 个问题.问题如下: 有一个函数f ...

  3. 腾讯云,搭建 FTP 文件服务

    腾讯云,搭建 FTP 文件服务 腾讯云,搭建 FTP 文件服务 安装并启动 FTP 服务 任务时间:5min ~ 10min 安装 VSFTPD 使用 yum 安装 vsftpd: yum insta ...

  4. 基于eth快速发行自己的数字货币

    我们总在寻觅,也不断迷失. 像一颗飘摇的韭菜,彷徨而又无奈,无奈又彷徨. 如果你问我未来,我不知去向何方 我只知道生长,恣意野蛮. 我们不断在追寻一款爆款的项目,一个百倍币千倍币,却没有想到,实际上做 ...

  5. Java 无法初始化Connection的问题

    通过断点调试捕获错误消息:The server time zone value '�й���׼ʱ��' is unrecognized or represents more than one time ...

  6. lintcode-118-不同的子序列

    118-不同的子序列 给出字符串S和字符串T,计算S的不同的子序列中T出现的个数. 子序列字符串是原始字符串通过删除一些(或零个)产生的一个新的字符串,并且对剩下的字符的相对位置没有影响.(比如,&q ...

  7. 【CF Round 434 A. k-rounding】

    Time limit per test1 second memory limit per test 256 megabytes input standard input output standard ...

  8. Planning your upgrade with Upgrade Advisor

    Planning your upgrade with Upgrade Advisor You should use the Upgrade Advisor tool (if it is availab ...

  9. SQLyog 使用笔记,自增主键数据冲突错误

    select max(id) from test ; desc test ; insert into  test (a,b,c) values ('abc','123-213','test'); RE ...

  10. 布局之BFC

    BFC 什么是BFC,在哪里需要用到BFC,BFC有什么规则?生成BFC有什么条件?这几个问题,我将为大家一一解释,下面我们进入正题. BFC(Block formatting context)直译为 ...