VisualVM如何查看HashMap对象实际使用内存大小

最近在做一个java项目,需要处理大量的实时数据,为了效率将这些数据存放到了HashMap里。刚开始估计项目运行起来,这些HashMap可以要消耗100M以上内存,为以后的扩展带来隐患。

于是打开JDK/bin目录下的VisualVM工具,选中SpringBoot的java进程,对内存进行了分析。使用过滤器找到KLineMapBean这个java类,它仅有一个实例,在下图中可以清晰的看到每个HashMap对象使用内存的大小。整个KLineMapBean实例所需内存不到15M,远低于我的预估值。


  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在Linux中,可以使用工具来查看Java对象内存大小。常用的工具有jmap、jvisualvm和MAT(Memory Analyzer Tool)。 1. jmap: jmap是JDK自带的一个命令行工具,可以用于生成Java堆转储快照(heap dump)。通过分析转储文件,可以获取对象内存大小使用以下命令生成堆转储文件: ``` jmap -dump:format=b,file=dump.bin <pid> ``` 其中,`<pid>`是Java进程的进程ID。生成的堆转储文件可以在MAT等工具中进行分析。 2. jvisualvm: jvisualvm是JDK自带的图形化监控和分析工具。通过安装VisualVM-MBeans插件,可以在jvisualvm查看对象内存大小。具体操作如下: - 启动jvisualvm。 - 安装VisualVM-MBeans插件:点击“Tools”->“Plugins”,选择“Available Plugins”标签,找到并安装“VisualVM-MBeans”插件。 - 连接到Java进程:在左侧导航栏的“Applications”下,选择要连接的Java进程。 - 打开“MBeans”标签页,展开“com.sun.management”->“HotSpotDiagnostic”->“Operations”,找到并执行“dumpHeap”操作,将堆转储到文件。 - 打开“Profiler”标签页,点击“Heap Dump”按钮,选择刚刚生成的转储文件进行分析。 3. MAT(Memory Analyzer Tool): MAT是一款功能强大的Java堆转储分析工具,可以通过分析堆转储文件来查看对象内存大小。可以使用jmap生成堆转储文件,然后使用MAT打开并分析该文件。 以上是一些常用的工具,可以帮助你在Linux中查看Java对象内存大小。具体选择哪种工具,可以根据自己的需求和习惯来决定。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值