方法一:jol-core包:
先创建一个静态成员变量之后new1000个Object打印出来这个对象的大小只有64byte.大家一看就知道肯定是有问题的后面再说.
// 先引入坐标
<dependency>
<groupId>org.openjdk.jol</groupId>
<artifactId>jol-core</artifactId>
<version>0.9</version>
</dependency>
private static ConcurrentHashMap<String,Object> map
= new ConcurrentHashMap<>();
// 往map里面插入1000个Object
public static void main(String[] args) {
for (int i = 0; i < 1000; i++) {
map.put(String.valueOf(i),new Object());
}
System.out.println(ClassLayout.
parseInstance(map).toPrintable());
}
方法二:lucene-core包
这里跟上面做了相同的操作,但是这次大小占用了100多k.
// 引入坐标
<dependency>
<groupId>org.apache.lucene</groupId>
<artifactId>lucene-core</artifactId>
<version>4.0.0</version>
</dependency>
private static ConcurrentHashMap<String,Object> map
= new ConcurrentHashMap<>();
// 往map里面插入1000个Object
public static void main(String[] args) {
for (int i = 0; i < 1000; i++) {
map.put(String.valueOf(i),new Object());
}
System.out.println(RamUsageEstimator
.humanSizeOf(map));
}
总结:我们可以发现RamUsageEstimator
.humanSizeOf这个方法是返回当前对象和该对象里面所有对象占用内存的总和大小,而ClassLayout.
parseInstance(Object).toPrintable()这个方法只获取Object这个对象自己所占内存大小.