在循环中调用list.add()数据覆盖问题

在for循环中使用List<T>.add()可能会导致内容被覆盖,尤其是当T为引用类型时。原因是每次添加都在同一个对象上操作。为避免此问题,可以在循环内新建对象或使用如HashMap的容器存储。两种解决方案分别是:在循环内每次都new一个新的对象,或者使用静态HashMap存储并用方法返回。
摘要由CSDN通过智能技术生成

遍历数组的同时在for循环中使用list.add(),但这样会将之前的内容也覆盖掉。本来有6条数据,但这样会得到6条相同的数据。

原因分析:

当使用List<T>时,如果T是引用类型,保存的是引用,如果是值类型,保存的是值本身。

  1. T是引用类型时,在循环外边已经new了一个对象,相当于这个对象的地址在内存空间已经开辟出来了,保存到了固定的位置,这时候我们使用add方法时,会增加值的个数,但引用地址不变,所以后面的值会覆盖掉前面的值,也就是说你只创建了一个对象,在存储过程中不停往这一个对象添加数据。

  1. T是值时,值对象用来保存一组不会改变的量,当我们需要使用这个对象时,会在系统中开辟另一个空间。因此,值对象使用add方法时不会出现覆盖问题。

解决方案:

在循环中将对象再new一次

解决方案2:

设置一个类似private static HashMap进行存储,然后使用一个方法返回当前HashMap。

原文链接https://blog.csdn.net/printf88/article/details/116133236

JavaList是一种非常常用的数据结构,它可以存储多个对象,而且可以动态扩展或缩小。很多时候,我们需要对List数据进行删除操作。 一般来说,List有两种删除方式,一种是通过元素索引删除,另一种是通过元素对象删除。我们可以使用“remove(index)”方法来删除指定索引位置的元素,也可以使用“remove(object)”方法来删除指定对象。 但是,在List删除操作并不是完全没有限制的。如果在List遍历过程进行删除操作,容易出现并发修改异常,因为删除操作可能会导致索引位置的变化,而这时候List的迭代器可能就无法正常处理了。 为了避免这种情况,我们可以使用迭代器自身的remove方法进行元素删除,这种方式会在删除时同步更新迭代器状态,保持迭代器与List的一致性。具体操作如下: List<String> list = new ArrayList<>(); list.add("A"); list.add("B"); list.add("C"); Iterator<String> iterator = list.iterator(); while (iterator.hasNext()) { String item = iterator.next(); if ("B".equals(item)) { iterator.remove(); } } 上面的代码演示了如何使用迭代器遍历List并删除元素。在遍历过程,如果发现需要删除的元素,则调用迭代器的remove方法进行删除。这样就可以避免删除操作导致的并发修改异常问题。 总之,在进行List删除操作时,需要注意遍历过程不能直接调用List的删除方法,而应该使用迭代器自身的remove方法进行删除,以保持迭代器与List的一致性。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值