gsh6022 2020-07-30 19:11 采纳率: 100%
浏览 186
已采纳

JVM堆内存溢出问题,对于同一段代码只是打印了一下长度

求有智慧的大佬回答一下此问题
划重点,我问的是上面的代码为什么不OOM!!!

private static void testOldHeap2() {
        List<String> list = new ArrayList<String>();
        String s = "ssa";
        list.add(s);
        while(true){
            list.add(s);
            System.out.println(list.size());
        }

    }

此片段代码不会内存溢出,jdk版本1.8


private static void testOldHeap2() {
        List<String> list = new ArrayList<String>();
        String s = "ssa";
        list.add(s);
        while(true){
            System.out.println(list.size());
        }

    }

这段代码大概20s不到就会抛出内存溢出,很奇怪,我想不明白为什么
此为内存溢出截图

  • 写回答

3条回答 默认 最新

  • 牧子与羊 2020-07-31 09:26
    关注

    我这么给你说吧,做print打印的时候需要消耗时间,也就是假定list的size达到100w会溢出,那么打印花费时间需要60s,不打印需要0.5s,也就是你说的为什么没打印20s就溢出了。我们可以做个验证
    图片说明,你把内存(-Xmx10m)设置小一点,很快就能验证我的说法。望采纳

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(2条)

报告相同问题?

悬赏问题

  • ¥30 Matlab打开默认名称带有/的光谱数据
  • ¥50 easyExcel模板 动态单元格合并列
  • ¥15 res.rows如何取值使用
  • ¥15 在odoo17开发环境中,怎么实现库存管理系统,或独立模块设计与AGV小车对接?开发方面应如何设计和开发?请详细解释MES或WMS在与AGV小车对接时需完成的设计和开发
  • ¥15 CSP算法实现EEG特征提取,哪一步错了?
  • ¥15 游戏盾如何溯源服务器真实ip?需要30个字。后面的字是凑数的
  • ¥15 vue3前端取消收藏的不会引用collectId
  • ¥15 delphi7 HMAC_SHA256方式加密
  • ¥15 关于#qt#的问题:我想实现qcustomplot完成坐标轴
  • ¥15 下列c语言代码为何输出了多余的空格