java freememory 单位_如何跟踪Java中的任何对象创建,因为freeMemory()只报告长期存在的对象?...

每当我的JVM创建一个新对象时,我想在日志中打印一些东西。我试图使用Runtime.getRuntime()。freeMemory()来检测,但不幸的是它没有考虑到任何短暂的对象,直到它被提升到堆(check here for more details)。

那么有没有人知道如何检测/跟踪每当一个对象由我的JVM实例化/创建?为了更容易,我们如何完成下面的代码:

随意使用MemoryPoolMXBean和JMX:

public class MemoryUtils {

private static Set set = new HashSet();

public static void main(String[] args) {

// START

// now create a bunch of objects and save them in the set

for (int i = 0; i < 100; i++) {

set.add(new String("foo" + i));

}

// FINISH

// FIXME: Do something here to detect that a bunch of objects were created!

}

}编辑:尝试下面的弗拉基米尔提出的解决方案:

它有效,但有一个奇怪的副作用:

long t = totalThreadMemoryAllocated();

// did nothing

t = totalThreadMemoryAllocated() - t;

System.out.println(t); // ==> 48 !!!???

public static long totalThreadMemoryAllocated() {

com.sun.management.ThreadMXBean tBean = (com.sun.management.ThreadMXBean) ManagementFactory.getThreadMXBean();

return tBean.getThreadAllocatedBytes(Thread.currentThread().getId());

}但它确实解释了任何对象的创建,所以我想我可以使用这个,如果我从它减去48的魔术数。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值