Java中从list中删除符合条件的数据

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

public class Test1 {
	 public static void main(String[] args) {
	        ArrayList<String> strs = new ArrayList<>();
	        strs.add("1");
	        strs.add("32");
	        strs.add("3");
	        strs.add("4");
	        strs.add("5");
	        strs.add("36");

	       // remove1(strs);
	        //remove2(strs);
	          //remove3(strs);
	        remove4(strs);
	        System.out.println("after");
	        printList(strs);
	    }

	    //使用iterator,这个是java和Android源码中经常使用到的一种方法,所以最为推荐
	    public static void remove1(List<String> list) {
	        Iterator<String> sListIterator = list.iterator();
	        while (sListIterator.hasNext()) {
	            String str = sListIterator.next();
	            if (str.equals("3")) {
	                sListIterator.remove();
	            }
	        }
	    }

	    //倒序删除,以防因为删除中间项导致数据下标变更,使得数据出错
	    public static void remove2(List<String> list) {
	        for (int i = list.size() - 1; i >= 0; i--) {
	            if (list.get(i).equals("3")) {
	                list.remove(i);
	            }
	        }
	    }

	    // 在遍历过程中不直接操作原list
	    public static void remove4(List<String> list) {
	        List<String> temp = new ArrayList<>();
	        for (String str : list) {
	            if (str.equals("3")) {
	                temp.add(str);
	            }
	        }
	        list.removeAll(temp);
	    }

	    public static void printList(List<String> list) {
	        for (String str : list) {
	            System.out.println(str);
	        }
	    }
}

ArrayList删除源码

// 移除指定索引的元素
nums.remove(1);
public E remove(int index) {
    // 检测指定的索引是否越界
    rangeCheck(index);

    modCount++;
    // 获取待移除的元素,操作完成后返回
    E oldValue = elementData(index);

    // 计算出 index 之后元素的个数
    int numMoved = size - index - 1;
    if (numMoved > 0)
        // 调用 arraycopy 方法将 index 之后的元素向前移动一位,将 index 位置的元素覆盖掉
        System.arraycopy(elementData, index+1, elementData, index,
                         numMoved);
    // 将数组最后位置的值置为 null
    elementData[--size] = null; // clear to let GC do its work

    return oldValue;
}

根据源码可知,在删除index位置的元素时,要先调用rangeCheck(index)进行index的check,index要超过当前个数,则判定越界,抛出异常,throw new IndexOutOfBoundsException(outOfBoundsMsg(index));其他方法也有用到如:get(int index),set(int index, E element)等后面删除重点在于计算删除的index是末尾还是中间位置,末尾直接–,然后置空完事,如果是中间位置,那就要进行一个数组间的copy,重新组合数组数据了,性能就在这里得到了消耗。

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值