测试内存占用

看到业务代码出现了类似list=null, map.clear()这种存储了大量对象的集合进行释放内存的操作,因此测试一下其必要性

代码
public class MemoryTest {

    public static void main(String[] args) throws Exception{
        long initm=Runtime.getRuntime().freeMemory();
        List<Item> items = new ArrayList<>();
        Item item = new Item();
        item.setPrice(1);
        item.setQuantity(2);
        item.setAlias("1");
        for (int i = 0; i < 10000000; i++) {
            items.add(item);
        }
        long endm=Runtime.getRuntime().freeMemory();
        System.out.println("初始内存: " + initm/1024/1024 + "M");
        System.out.println("结束内存: " + endm/1024/1024 + "M");
        System.out.println("内存占用: " +  (initm-endm)/1024/1024 + "M");

        System.out.println("=======================通过java来获取相关系统状态============================ ");
        int i = (int)Runtime.getRuntime().totalMemory()/1024/1024;//Java 虚拟机中的内存总量,以字节为单位
        System.out.println("总的内存量: " + i + "M");
        int j = (int)Runtime.getRuntime().freeMemory()/1024/1024;//Java 虚拟机中的空闲内存量
        System.out.println("空闲内存量: " + j + "M");
        System.out.println("最大内存量: "+ Runtime.getRuntime().maxMemory()/1024/1024);

        items = null;
        for (int k = 0; k < 100; k++) {
            System.out.println("=======================gc " + (k+1) + "次============================ ");
            System.gc();
            Thread.currentThread().sleep(1000);
            int ii = (int)Runtime.getRuntime().totalMemory()/1024/1024;//Java 虚拟机中的内存总量,以字节为单位
            System.out.println("总的内存量: " + ii + "M");
            int jj = (int)Runtime.getRuntime().freeMemory()/1024/1024;//Java 虚拟机中的空闲内存量
            System.out.println("空闲内存量: " + jj + "M");
            System.out.println("最大内存量: "+ Runtime.getRuntime().maxMemory()/1024/1024 + "M");
            if (ii - jj < 10){
                System.out.println("=======================内存释放满足条件============================ ");
                System.out.println(ii + "--" + jj);
                break;
            }
        }

    }

}

执行结果

执行结果

结论
  • 当数据量很大时,比如同步钉钉组织架构的场景,大企业几十万人,会涉及到上百兆内存,应及时释放
  • 尽量运用对象池技术以提高系统性能 :生命周期长的对象拥有生命周期短的对象时容易引发内存泄漏,例如大集合对象拥有大数据量的业务对象的时候,可以考虑分块进行处理,然后解决一块释放一块的策略
  • 如下
List list = null;
for(;;){
list = fetch(data, limit);
if(list.isEmpty()){
 break;
}
process(list);
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值