JVM 测试结果分析

本文探讨了JVM中内存分配的情况,通过实例展示了Object数组直接分配内存的效率,以及ArrayList和LinkedList在大量数据添加时对内存的影响。ArrayList在接近12亿元素时遇到限制,而LinkedList的连续添加会导致频繁的Full GC,每次耗时33秒,但并未观察到OOM问题。
摘要由CSDN通过智能技术生成

1 Object[] objects = new Object[100000];

会直接分配内存

2. ArrayList<Byte> 不允许一直添加数据添加超过1,197,571,636 接近12亿

for (; i <= Integer.MAX_VALUE - 3; i++) {
    list.add(tb);
}

LinkedList<Byte> 一直添加数据会引起Full GC,每次Full GC 33s,但很长时间没有发现OOM

/**
 * Created by on 2018/5/19.
 */
public class ComputeObjectSize {

    public static void main(String[] args) {
        //指针不压缩8
        // 对象头(8) + 对象指针(8) + 数组长度(4) + 实例数据(8 * 10) + Padding(4) = 104
        //指针压缩4
        //对
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值