文档章节

Java 内存空间占用规则分析

年少爱追梦
 年少爱追梦
发布于 2016/08/12 15:27
字数 1042
阅读 31
收藏 1

 

一个对象实例占用了多少字节,消耗了多少内存?这样的问题在c或c++里使用sizeof()方法就可以得到明确答案,在java里好像没有这样的方法(java一样可以实现),不过通过jmap工具倒是可以查看出一个对象的占用内存的大小,这里介绍一种通过分析java代码计算内存使用情况的方法。

注意,一下讨论的情况都是基于32位机,不适用用64位机,JVM是sun的HotSpot,不同的虚拟机实现可能会不同

 

规则一:每个对象被按照8bytes粒度对齐(数组除外)

 

在jvm中每个对象(数组除外)都有一个头,这个头有两个字,第一个字存储的时对象的一些标志位信息,例如:锁标志位、经历了几次gc等信息,第二个字是一个引用,指向了这个类的类信息。这里jvm给这两个字留了8个字节的空间(这个为啥用8个字节空间不是很清楚,一个字即两个字节,我一直认为4个字节就够了)

按规则一:new Object();这个Object实例就占用了8个字节

 

规则二:为类属性分配存储空间时不是按照类中定义的属性顺序,而是按如下的顺序:

            1、double\long;----8bytes

            2、int\float;----4bytes

            3、char\short;----2bytes

            4、boolean\byte;----1bytes

            5、reference;----4bytes

例如:

Java代码  

public class A {   

    byte a;   

    char b;   

    int c;   

    long d;   

    Object e;   

}   

 

 

 

属性        需要字节数        累积字节数

header        8bytes        8

long:d        8bytes        16

int:c        4bytes        20

char:b        2bytes        22

byte:a        1bytes        23

Object:e        4bytes        27

         padding 5bytes        32 

 

最后一行padding 5bytes的目的是,规则一中描述每个对象按照8个字节的粒度对齐,这样下一个分配的对象的开始位置必须在8的倍数上,而离27最近的8的倍数是32,因此加了5bytes。A占用32bytes

可以用jmap看一下这个计算是否准确

 

规则三:对于继承时,要按照规则二先计算父类的类属性占用情况,再按照规则二计算子类的类属性占用情况,不能将父类和子类的属性混合在一起按规则二分配。

例如:

Java代码  

class B{  

    long a;  

    int b;  

    int c;  

}  

 

class BB extends B{  

    long d;  

}  

 

 属性        占用字节数        累计字节数

header        8        8

a        8        16

b        4        20

c        4        24

d        8        32

 

这里累计字节正好是8的倍数,满足规则一,因此不用padding字节。BB对象内存占用了32bytes

 

规则四:父类的最后一个属性和子类第一个属性必须按4个字节的倍数对齐

例如:

Java代码  

class B{  

    long a;  

    int b;  

    char c;  

}  

 

class BB extends B{  

    long d;  

}  

 

 

属性        占用的字节        累计字节

head        8        8

a        8        16

c        2        18

         padding 2        20

d        8        28

         padding 4        32

 

第一次padding2是因为属性c分配内存后,不满足父类最后一个属性和子类第一个属性按4字节粒度对齐(18除4除不开),因此需要添加两个字节使其可以按4字节粒度对齐。

第二次paadding4是依据规则一

 

规则五:当子类的第一个属性是double或long,但是父类不能按8字节粒度对齐时,子类内存分配时的顺序将不按规则二进行,而是按:先int\float、char\short、boolean\byte、reference、long\double

 

例如:

Java代码  

class A{  

    byte a;  

}  

 

class B extends A{  

    long b;  

    short c;  

    byte d;  

}  

 

 

属性        占用字节数        累计占用字节数

head        8        8

a        1        9

         padding 3        12

c        2        14

d        1        15

         padding 1        16

b        8        24

 第一次 padding 3是根据规则四

 第二次 padding 1是因为b属性是8个字节,因此需要按8个字节粒度对齐。B占用24bytes

 

 对于数组,与普通对象不同的是在头部,头部多了4个字节用于存储长度信息。因此数组的head是12bytes而不是8bytes

本文转载自:http://zhwj184.iteye.com/blog/1513016

共有 人打赏支持
年少爱追梦
粉丝 31
博文 184
码字总数 117969
作品 0
杭州
程序员
私信 提问
new一个Object对象占用多少内存?

Java的自动内存管理机制(automatic storage management system known as a garbage collector)省却了很多编码工作,大大地提高了Java的生产力,而且JVM的性能也越来越好,特别是G1的出现,...

杨尚川
2014/03/15
0
7
JVM汇总--jvm调优-命令篇

GC的最根本原因:垃圾收集器的工作就是清除Java创建的对象,垃圾收集器需要清理的对象数量以及要执行的GC数量均取决于已创建的对象数量。因此,为了使你的系统在GC上表现良好,首先需要减少创...

素雷
04/12
0
0
JVM性能调优实践——JVM篇

前言 在遇到实际性能问题时,除了关注系统性能指标。还要结合应用程序的系统的日志、堆栈信息、GClog、threaddump等数据进行问题分析和定位。关于性能指标分析可以参考前一篇JVM性能调优实践...

lijingyao8206
05/24
0
0
Metaspace溢出排查过程

庞彤彤 2014年8月加入去哪儿,目前就职于大住宿事业部,主要负责交易运营相关内容。 一、问题 线上的 task 服务出现报警,没有服务者,发现有的机器突然下线了。 第一次出现问题时,发现服务...

Qunar技术沙龙
06/12
0
0
如何合理的规划一次jvm性能调优

这是jvm优化系列第三篇: jvm优化——垃圾回收 jvm优化——监控工具 JVM性能调优涉及到方方面面的取舍,往往是牵一发而动全身,需要全盘考虑各方面的影响。但也有一些基础的理论和原则,理解...

wier
2017/10/25
0
9

没有更多内容

加载失败,请刷新页面

加载更多

w, vmstat, top, sar, nload命令查看系统状态信息

w/uptime 查看系统负载 cat /proc/cpuinfo 查看cpu核数 vmstat 监控系统状态,用法 vmstat 1,关键的几列: r, b, swpd, si, so, bi, bo, us, wa top 查看进程使用资源情况 top -c 显示详细的...

野雪球
今天
1
0
小白创建一个spring boot项目

进入 https://start.spring.io/

lilugirl
今天
2
0
Alibaba Java诊断利器Arthas实践--使用redefine排查应用奇怪的日志来源

背景 随着应用越来越复杂,依赖越来越多,日志系统越来越混乱,有时会出现一些奇怪的日志,比如: [] [] [] No credential found 那么怎样排查这些奇怪的日志从哪里打印出来的呢?因为搞不清...

hengyunabc
今天
2
0
home hosts

home hosts lwk@qwfys:~$ cat /etc/hosts127.0.0.1 localhost127.0.1.1 qwfys192.168.56.101vm600.qwfys.com39.108.212.91alpha1.ppy.com39.108.117.122alpha2.p......

qwfys
今天
3
0
大数据教程(6.1)hadoop生态圈介绍及就业前景

1. HADOOP背景介绍 1.1、什么是HADOOP 1.HADOOP是apache旗下的一套开源软件平台 2.HADOOP提供的功能:利用服务器集群,根据用户的自定义业务逻辑,对海量数据进行分布式处理 3.HADOOP的核心组...

em_aaron
今天
5
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部