jmap -histo 输出的[C [S [I [B [[I

本文解析了使用jmap-histo指令查看Java应用内存中对象占用情况时出现的特殊符号含义,如[C、[S、[I等,帮助读者理解不同类型的数组在内存中的表现。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

 num     #instances         #bytes  class name
----------------------------------------------
   1:         29213      129250632  [B
   2:         31358       25795944  [I
   3:        181179       18582112  [C

在使用jmap -histo指令查看对象占用的时候经常会看到[C [S [I [B [[I这些,他们分别代表着

[C is char[]

[S is short[]

[I is int[]

[B is byte[]

[[I is int[][]

### jmap -histo 命令详解 #### 功能概述 `jmap -histo` 是 Java 内存分析工具之一,用于显示指定 Java 进程堆内存中对象的数量、大小统计直方图。当附加 `:live` 参数时,则仅统计存活的对象[^3]。 #### 使用方法 基本语法结构如下: ```bash jmap -histo[:live] <pid> ``` - `<pid>` 表示目标 Java 应用程序的进程 ID。 - 如果加上 `:live` 选项,命令会遍历整个堆并计算活动对象的信息;如果不加此参数,默认情况下也会给出所有已分配过的对象的历史数据,即使这些对象已经被垃圾回收器清理掉[^2]。 #### 输出重定向至文件 为了便于后续处理或保存记录,可以将输出结果重定向到文件中: ```bash jmap -histo:live <pid> > output_file_path ``` 这行指令将会把当前进程中所有的活跃对象按类名排序,并将其数量与所占字节数写入指定路径下的文件里[^1]。 #### 示例解释 假设执行了带有 `:live` 标志的命令后得到的部分输出类似于下面这样: ```plaintext num #instances #bytes class name ---------------------------------------------- 1: 948 37920 java.util.concurrent.ConcurrentHashMap$Segment ... ``` 这里每一列表达的意义分别是: - **num**: 排序编号; - **#instances**: 对应类型的实例总数; - **#bytes**: 所有该类型实例占据的空间总和(单位为字节); - **class name**: 类全限定名称[^4]。 通过上述信息可以帮助开发者了解应用程序运行期间不同种类对象的实际消耗状况,从而辅助性能调优工作。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值