栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

线程消耗的内存

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

线程消耗的内存

据我所知,没有可靠的方法可以在运行时执行此操作。正如源问题中指出的那样,堆是共享资源,因此单个线程的堆大小没有意义,因为它会与其他线程的对象引用重叠。

就是说,当我确实想知道单个线程的“保留”大小,是的,保留大小与您所要求的度量标准是不同但相似的指标时,我可以通过进行堆转储然后使用MAT来实现。
(http://www.eclipse.org/mat/)。

我知道有人使用Java代理来检测对象的分配,然后使用弱引用来监视何时获得GC。但是,这样做对性能的影响很大。很高。

最好在运行时和单元测试中使用启发式方法,以确保内存保持在界限之内。例如,您可以使用JMX来监视堆大小,并且当您看到旧一代正在增长时,您可以发出警报。使用getThreadAllocatedBytes计算分配率也可能很有用。

良好的运行时间监控工具:
appdynamics,NewRelic的,VisualVM的和yourkit

对于离线内存分析,mat和jclarity非常好。

一个非常有用的工具可以帮助您发现是否存在泄漏,或者至少运行得与预期不同,它是打印当前每个类在堆上有多少实例的计数: jcmd GC.class_histogram



转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/515149.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号