目录
上一篇日志最后说到,非静态类型变量经过起始偏移量和5中类型偏移量计算后,在统计总的内存空间大小前,需要进行内存对齐补白操作,这样做的原因是性能带来了提升,上一篇举过例子,对于进行了补白对齐的数据,CPU进行访问可能只需要一个周期即可,反过来如果内存起始地址并不是数据字节的倍数,那么可能读取某一数据时需要分两步到三步,将不同内存地址的数据读取出来后,去除头和尾多余的字节拼凑出目标地址的结果出来。总的来说,如果内存起始地址是x字节长度的倍数,那么说明该x字节是内存对齐的,32位操作系统下例如int变量类型长度为4个字节,那么规则也是按4的倍数来对齐。
字节对齐
如果变量数据的内存起始地址是字节对齐的,那么对该数据的读取就是高效安全的,因为不需要分多个周期进行读取,拼凑。对于Java和C、C++、C#这类高级语言,因为编译器的存在,编译器或虚拟机会自动帮我们进行字节对齐补白,来看一个例子。
struct示例

上面的程序中先是声明了两个结构体A和B,它们里面都有三个变量,int i、char c和short s,在32位系统下int型的i变量大小为4个字节,char型变量c大小1字节,short型变量大小为2字节,

本文介绍了JVM中的字节对齐原则,通过struct示例和内存布局分析,揭示了不同变量声明顺序如何影响内存大小。文章还探讨了字段重拍在优化内存空间方面的作用,并指出Java字节对齐规则及其内存利用率的提升策略。
最低0.47元/天 解锁文章
972

被折叠的 条评论
为什么被折叠?



