Java易错知识点(1) - 关于ArrayList移除元素后剩下的元素会立即重排
帮一个网友解答问题时,发现这样一个易错知识点,现总结如下:
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移除元素后剩下的元素会立即重排的更多相关文章
- Java易错知识点(2) - 在读取Cookie时除了Key,Value是得不到其他信息的
全文总结: 在读取Cookie,然后操作时,除了getName(),getValue()外,不要妄图得到其他信息,如下方法不会得到值的: cookie.getMaxAge(); cookie.getD ...
- JavaScript易错知识点整理
前言 本文是我学习JavaScript过程中收集与整理的一些易错知识点,将分别从变量作用域,类型比较,this指向,函数参数,闭包问题及对象拷贝与赋值这6个方面进行由浅入深的介绍和讲解,其中也涉及了一 ...
- JavaScript 易错知识点整理
本文是我学习JavaScript过程中收集与整理的一些易错知识点,将分别从变量作用域,类型比较,this指向,函数参数,闭包问题及对象拷贝与赋值这6个方面进行由浅入深的介绍和讲解,其中也涉及了一些ES ...
- JavaScript易错知识点整理[转]
前言 本文是我学习JavaScript过程中收集与整理的一些易错知识点,将分别从变量作用域,类型比较,this指向,函数参数,闭包问题及对象拷贝与赋值这6个方面进行由浅入深的介绍和讲解,其中也涉及了一 ...
- JS易错知识点
JAVASCRIPT易错知识点整理 前言 本文是学习JavaScript过程中收集与整理的一些易错知识点,将分别从变量作用域,类型比较,this指向,函数参数,闭包问题及对象拷贝与赋值这6个方面进行由 ...
- 【笔试题】Java 易错题精选
笔试题 Java 易错题精选 1.写出下列程序的运行结果( )String 不变性Java 值传递 public class Test { public static void main(String ...
- JavaScript易错知识点
JavaScript易错知识点整理1.变量作用域上方的函数作用域中声明并赋值了a,且在console之上,所以遵循就近原则输出a等于2. 上方的函数作用域中虽然声明并赋值了a,但位于console之下 ...
- java易错基础知识点
一. Switch 1.其能接受的数据类型有四个,char , byte, short, int2.Default 可放在switch中的任何一个地方,但只有给定的条件匹配不到时,才会执行3.Case ...
- [置顶] 单片机C语言易错知识点经验笔记
今天写这一篇文章并不是因为已经想好了一篇文章才写下来,而是我要将这一篇文章作为一个长期的笔记来写,我会一直更新.在进行单片机开发时,经常都会出现一些很不起眼的问题,这些问题其实都是很基础的c语言知识点 ...
随机推荐
- centos7源码安装cloud-init
<template> <name>centos72-source</name> <os> <name>CentOS-7</name&g ...
- React远程服务
http://web1.dev5.net:3002/cloud/start?server=exf2&name=zhangxiaocong http://web1.dev5.net:3002/c ...
- linux备忘录-系统服务daemon
服务(daemon)及其分类 Linux中的服务被称为daemon(daemon是守护神,恶鬼的意思哦).这些daemon会常驻在内存当中,从而对我们的系统和任务等进行一些辅助性的工作.实际上,dae ...
- HDU 1271 整数对(思路题)
假设删除第k位,把整数A表示成如下形式: A = a * 10^(k+1) + b * 10 ^k + c; 则: B = a * 10^k + c; N = A + B = (11*a+b)*10^ ...
- 关于Android Studio启动后自己的配置
根据Android Stduio自己设置的配置,我们在执行一些操作时可能不向教程那样,此时就要看教程上的Android Stduio的设置.
- Daily Scrum02 12.04
第二轮迭代已经进行到了白热化阶段,大家在被编译搞的水深火热的同时依然没有忘记我们的具有颠覆性的团队项目.虽然第一轮迭代我们的成绩不错,但是一定要克服时间不充裕,任务互相冲突的困难,克服不可避免的舆论压 ...
- PAT 1090 危险品装箱
https://pintia.cn/problem-sets/994805260223102976/problems/1038429484026175488 集装箱运输货物时,我们必须特别小心,不能把 ...
- 下拉框select chosen被遮盖
最简单的就是让容器高度大点. 用js调整也行. 为什么z-index不管事,看下面... 浏览器支持 所有主流浏览器都支持 z-index 属性. 注释:任何的版本的 Internet Explore ...
- hdu 6200 mustedge mustedge(并查集+树状数组 或者 LCT 缩点)
hdu 6200 mustedge mustedge(并查集+树状数组 或者 LCT 缩点) 题意: 给一张无向连通图,有两种操作 1 u v 加一条边(u,v) 2 u v 计算u到v路径上桥的个数 ...
- jQuery源码分析笔记
jquery-2.0.3.js版本源码分析 (function(){ (21,94) 定义了一些变量和函数 jQuery = function(){}; (96,283) 给JQ对象,添加一些方法 ...