Java集合的内存开辟及存储问题

1.先上问题出现的错误举例。

public static void main(String[] args) {
        Random random = new Random();
        //简称为第一集合
        List<Set> arrList = new ArrayList<>();
        //简称为第二集合
        Set<Integer> strList = new TreeSet<>();
        for (int i = 0; i < 5; i++) {
            strList.clear();
            while (strList.size() <4){
                int i1 = random.nextInt(31)+1;
                strList.add(i1);
            }
            arrList.add(strList);
        }
        System.out.println(arrList);

    }

上图的运行结果为:

[[12, 16, 18, 23], [12, 16, 18, 23], [12, 16, 18, 23], [12, 16, 18, 23], [12, 16, 18, 23]]

代码解释:

1.while循环是创建一个size为4的随机数集合,如果集合的元素个数达到4个,则会结束while循环。(每个数据都是通过random创建出来的随机数)。

2.for循环时将while结构循环5次,也就是说创建5个带有5个随机数的集合。

3.arrList.add(StrList):此代码是将每次while产生的集合存储在第一集合中。

4.但是明明是每次Random出来的数据都不相同,为什么最终数据都是同一个数组?

5.通过 调式也是可以了解到,当存储第二个集合的时候,就已经出现这种情况了。

6.那么为什么会出现此问题呢?是因为内存开辟以及指向的问题,稍后会将内存解析以及正确的代码展示出来。

2.上图代码的内存解析

 

 3.内存解析的相关解释:

1.第二集合是用于存储while循环产生的集合,

2.第一集合存放第二集合。但是一定要记住是存放第一集合的内存地址而并非数据。

3.上面代码出现问题时因为整个for循环只产生了一个第二集合的内存空间。虽然每次都会清除数据,但是在第一集合中存储的是第二集合的内存地址。因此当for循环执行第二轮时,是将第一集合的内存地址放到索引位置为2的地方,并且此时的第二集合的数据已经改变,因此第一集合索引为1的位置的数据也会改变。到此呢迷雾就已经全部揭开,下面展示出正确的代码。

4.正确的代码

public static void main(String[] args) {
        Random random = new Random();
        List<Set> arrList = new ArrayList<>();

        for (int i = 0; i < 5; i++) {
            Set<Integer> strList = new TreeSet<>();
            while (strList.size() <4){
                int i1 = random.nextInt(31)+1;
                strList.add(i1);
            }
            arrList.add(strList);
        }
        System.out.println(arrList);

    }

运行结果:

[[18, 21, 22, 31], [9, 13, 20, 25], [3, 7, 26, 28], [3, 10, 12, 20], [2, 6, 8, 24]]

 

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Java中,内存泄漏是指程序中的对象占用了内存空间,但在使用完毕后没有正确释放,导致这部分内存无法被垃圾回收器回收,进而造成内存泄漏问题。 常见的Java内存泄漏问题有以下几种情况: 1. 长生命周期对象持有短生命周期对象的引用:当一个长生命周期对象持有一个短生命周期对象的引用,并且长生命周期对象的生命周期比短生命周期对象长时,如果没有手动解除引用,短生命周期对象将无法被回收,导致内存泄漏。 2. 集合类未及时清空:在使用集合类时,如果没有及时清空或者手动删除元素,集合中的对象将一直存在于内存中,无法被回收。 3. 资源未关闭:在使用IO流、数据库连接、网络连接等资源时,如果没有及时关闭这些资源,会导致资源无法释放,从而造成内存泄漏。 4. 静态引用导致的内存泄漏:静态变量存在于整个应用程序的生命周期中,如果静态变量引用了其他对象,并且没有手动解除引用,那么这些对象将一直存在于内存中,无法被回收。 为了避免内存泄漏问题,可以采取以下几种措施: 1. 及时释放对象引用:在使用完对象后,尽量手动解除引用,让垃圾回收器能够回收不再使用的对象。 2. 使用弱引用或软引用:对于一些生命周期较长的对象,可以考虑使用弱引用或软引用来引用,这样当内存不足时,垃圾回收器会优先回收这些对象。 3. 使用try-with-resources语句块:在使用IO流、数据库连接等资源时,可以使用try-with-resources语句块来自动关闭资源,确保资源得到及时释放。 4. 使用合适的集合类:在使用集合类时,尽量使用合适的集合类,并在不需要时及时清空或手动删除元素,避免集合对象无法被回收。 通过以上措施,可以有效地避免Java中的内存泄漏问题

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值