IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 数据结构与算法 -> list集合遍历及删除注意事项 -> 正文阅读

[数据结构与算法]list集合遍历及删除注意事项

package com.github.wxiaoqi.security.generator.controller;

import java.util.ArrayList;
import java.util.Iterator;
import java.util.List;

public class test {
    public static void main(String[] args) {
        //进来方法后,首先初始化ArrayList,在走断点
        System.out.println("22");
        // 初始化参数为-1 就会报错java.lang.IllegalArgumentException: Illegal Capacity: -1
        // list最大值是 2147483638 2的31次方-8 超过这个值,系统就报内存溢出
        // 报错:java.lang.OutOfMemoryError: Requested array size exceeds VM limit
        // Object [] objects=  new Object[2147483638];;

        List<String> lists = new ArrayList<String>(3);
        System.out.println("333");
  for(int i=0;i<10;i++){
      lists.add(""+i);
  }
        //这样不会报错,可以删除list中元素
//         int l_size=lists.size();
//        for(int i=l_size-1;i>=0;i--){
//            if(lists.get(i).equals("2")){
//               lists.remove("2");
//            }
//        }

     //这样会引起下标越界,因为list移除一位,size减一,但是i是自增的
        // 报错:java.lang.IndexOutOfBoundsException: Index: 3, Size: 3
//     int l_size=lists.size();
//        for(int i=0;i<l_size;i++){
//            if(lists.get(i).equals("2")){
//               lists.remove("2");
//            }
//        }
      //只要list有添加或删除,modCount就会添加一,每次遍历时都会去检查对比是否有修改
        //报错:java.util.ConcurrentModificationException
        //
        //  private void fastRemove(int index) {
        //        modCount++;  //删除或新增时会加一
        //        int numMoved = size - index - 1;
        //        if (numMoved > 0)
        //            System.arraycopy(elementData, index+1, elementData, index,
        //                             numMoved);
        //        elementData[--size] = null; // clear to let GC do its work
        //    }
//        for(String s :lists){
//            if(s.equals("4")){
//                lists.remove(s);
//            }
//        }
      //如果是倒数第二位,不会报错,cursor和size是一样,最后一位不遍历
//        for(Iterator i = lists.iterator(); i.hasNext();){
//            String s = (String)i.next();
//            if(s.equals("3")){
//                lists.remove(s);
//            }
//        }

//        Iterator<String> it = lists.iterator();
//        while(it.hasNext()){
//            String x = it.next();
//            if(x.equals("8")){
//                it.remove();  //这个是跌倒器的remove,不是lists.remove
//                //  lists.remove("8"); //这样会报错
//            }
//        }
//        System.out.println(lists);
        //jdk1.8,集合数越多,扩容数量就越大,
//    int oldCapacity =1000;
//        int is= oldCapacity>>1;    //根据size,右移动,在扩容
//       int iss= Integer.MAX_VALUE - 8;
//        System.out.println("===="+iss);

        //挨个删除list元素




    }
}
  数据结构与算法 最新文章
【力扣106】 从中序与后续遍历序列构造二叉
leetcode 322 零钱兑换
哈希的应用:海量数据处理
动态规划|最短Hamilton路径
华为机试_HJ41 称砝码【中等】【menset】【
【C与数据结构】——寒假提高每日练习Day1
基础算法——堆排序
2023王道数据结构线性表--单链表课后习题部
LeetCode 之 反转链表的一部分
【题解】lintcode必刷50题<有效的括号序列
上一篇文章      下一篇文章      查看所有文章
加:2021-10-12 23:43:35  更:2021-10-12 23:45:00 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/6 17:50:47-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码