JVM调优总结(二)-一些概念[Java编程]
本文“JVM调优总结(二)-一些概念[Java编程]”是由七道奇为您精心收集,来源于网络转载,文章版权归文章作者所有,本站不对其观点以及内容做任何评价,请读者自行判断,以下是其具体内容:
Java对象的大小
基本数据的范例的大小是固定的,这里就不多说了.关于非基本范例的Java对象,其大小就值得商榷.
在Java中,一个空Object对象的大小是8byte,这个大小只是保存堆中一个没有任何属性的对象的大小.看下面语句:
Object ob = new Object();
这样在程序中完成了一个Java对象的生命,但是它所占的空间为:4byte+8byte.4byte是上脸部份所说的Java栈中保存引用的所需求的空间.而那8byte则是Java堆中对象的信息.因为全部的Java非基本范例的对象都需求默许担当Object对象,因此不管什么样的Java对象,其大小都必须是大于8byte.
有了Object对象的大小,我们便可以计算其他对象的大小了.
Class NewObject {
int count;
boolean flag;
Object ob;
}
其大小为:空对象大小(8byte)+int大小(4byte)+Boolean大小(1byte)+空Object引用的大小 (4byte)=17byte.但是因为Java在对对象内存分配时都是以8的整数倍来分,因此大于17byte的最接近8的整数倍的是24,因此此对象的大小为24byte.
这里需求注意一下基本范例的包装范例的大小.因为这种包装范例已经成为对象了,因此需求把他们作为对象来对待.包装范例的大小至少是12byte(声明一个空Object至少需求的空间),并且12byte没有包含任何有效信息,同时,因为Java对象大小是8的整数倍,因此一个基本范例包装类的大小至少是16byte.这个内存占用是很可怕的,它是利用基本范例的N倍(N>2),有些范例的内存占用更是浮夸(随便想下就知道了).因此,大概的话应尽大概少利用包装类.在JDK5.0今后,因为加入了自动范例装换,因此,Java虚拟机会在存储方面举行呼应的优化.
引用范例
对象引用范例分为强引用、软引用、弱引用和虚引用.
强引用:就是我们普通声明对象是时虚拟机生成的引用,强引用环境下,垃圾回收时需求严峻判断当前对象能否被强引用,假如被强引用,则不会被垃圾回收
软引用:软引用普通被做为缓存来利用.与强引用的辨别是,软引用在垃圾回收时,虚拟机会按照当前系统的剩余内存来决意能否对软引用举行回收.假如剩余内存对比慌张,则虚拟机会回收软引用所引用的空间;假如剩余内存相对富有,则不会举行回收.换句话说,虚拟机在发生OutOfMemory时,必定是没有软引用存在的.
弱引用:弱引用与软引用近似,都是作为缓存来利用.但与软引用差别,弱引用在举行垃圾回收时,是一定会被回收掉的,因此其生命周期只存在于一个垃圾回收周期内.
强引用不用说,我们系统普通在利用时都是用的强引用.而“软引用”和“弱引用”对比少见.他们普通被作为缓存利用,并且普通是在内存大小对比受限的情形下做为缓存.因为假如内存充足大的话,可以直接利用强引用作为缓存便可,同时可控性更高.因而,他们常见的是被利用在桌面利用系统的缓存.
以上是“JVM调优总结(二)-一些概念[Java编程]”的内容,如果你对以上该文章内容感兴趣,你可以看看七道奇为您推荐以下文章:
本文地址: | 与您的QQ/BBS好友分享! |