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

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. 牛客 小a与星际探索

    链接:https://ac.nowcoder.com/acm/contest/317/C来源:牛客网 小a正在玩一款星际探索游戏,小a需要驾驶着飞船从1号星球出发前往n号星球.其中每个星球有一个能量指 ...

  2. linux下easy_install的安装与使用详解

    Python中的easy_install工具用起来非常好用,它的作用类似于Php中的pear,或者Ruby中的gem,或者Perl中的cpan. 1.easy_install安装 如果想使用easy_ ...

  3. tomcat 启动报错 解决办法 A child container failed during

    控制台报错: Caused by: org.apache.catalina.LifecycleException: A child container failed during start at o ...

  4. Linux 项目实用命令

    总结一下Linux下常用的命令 nc nc命令,这是Linux一般都带有的,被誉为“瑞士军刀”.windows和Linux都有,可以下载安装对应的平台工具.使用UDP和TCP协议的网络连接去读写数据, ...

  5. BZOJ3132 上帝造题的七分钟 【二维树状数组】

    题目 "第一分钟,X说,要有矩阵,于是便有了一个里面写满了0的n×m矩阵. 第二分钟,L说,要能修改,于是便有了将左上角为(a,b),右下角为(c,d)的一个矩形区域内的全部数字加上一个值的 ...

  6. BZOJ2120 数颜色 【带修改莫队】

    2120: 数颜色 Time Limit: 6 Sec  Memory Limit: 259 MB Submit: 6579  Solved: 2625 [Submit][Status][Discus ...

  7. [COGS 622] [NOIP2011] 玛雅游戏 模拟

    整个模拟的关键除了打出来就是一个剪枝:对于两个左右相邻的块你不用再走←,因为走→是等效的 #include<cstdio> #include<cstring> #include ...

  8. COGS 930. [河南省队2012] 找第k小的数 主席树

    主席树裸板子 #include<cstdio> #include<iostream> #include<algorithm> #define MAXN 100005 ...

  9. POJ3259:Wormholes(spfa判负环)

    Wormholes Time Limit: 2000MS   Memory Limit: 65536K Total Submissions: 68097   Accepted: 25374 题目链接: ...

  10. 移动端list布局,左边固定,右边自适应

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="utf-8&quo ...