JAVA中引用本身占用内存空间的问题
来源:互联网 发布:mac最小化所有窗口 编辑:程序博客网 时间:2024/05/16 06:19
基本数据的类型的大小是固定的,这里就不多说了。对于非基本类型的Java对象,其大小就值得商榷。
在Java中,一个空Object对象的大小是8byte,这个大小只是保存堆中一个没有任何属性的对象的大小。看下面语句:
- Object ob = new Object();
有了Object对象的大小,我们就可以计算其他对象的大小了。
- class NewObject {
- int count;
- boolean flag;
- Object ob;
- }
这里需要注意一下基本类型的包装类型的大小。因为这种包装类型已经成为对象了,因此需要把他们作为对象来看待。包装类型的大小至少是12byte(声明一个空Object至少需要的空间),而且12byte没有包含任何有效信息,同时,因为Java对象大小是8的整数倍,因此一个基本类型包装类的大小至少是16byte。这个内存占用是很恐怖的,它是使用基本类型的N倍(N>2),有些类型的内存占用更是夸张(随便想下就知道了)。因此,可能的话应尽量少使用包装类。在JDK5.0以后,因为加入了自动类型装换,因此,Java虚拟机会在存储方面进行相应的优化。
引用类型
对象引用类型分为强引用、软引用、弱引用和虚引用。
强引用:就是我们一般声明对象是时虚拟机生成的引用,强引用环境下,垃圾回收时需要严格判断当前对象是否被强引用,如果被强引用,则不会被垃圾回收
软引用:软引用一般被做为缓存来使用。与强引用的区别是,软引用在垃圾回收时,虚拟机会根据当前系统的剩余内存来决定是否对软引用进行回收。如果剩余内存比较紧张,则虚拟机会回收软引用所引用的空间;如果剩余内存相对富裕,则不会进行回收。换句话说,虚拟机在发生OutOfMemory时,肯定是没有软引用存在的。
弱引用:弱引用与软引用类似,都是作为缓存来使用。但与软引用不同,弱引用在进行垃圾回收时,是一定会被回收掉的,因此其生命周期只存在于一个垃圾回收周期内。
强引用不用说,我们系统一般在使用时都是用的强引用。而“软引用”和“弱引用”比较少见。他们一般被作为缓存使用,而且一般是在内存大小比较受限的情况下做为缓存。因为如果内存足够大的话,可以直接使用强引用作为缓存即可,同时可控性更高。因而,他们常见的是被使用在桌面应用系统的缓存。
- JAVA中引用本身占用内存空间的问题
- JAVA中引用本身占用内存空间的问题
- JAVA中引用本身占用内存空间的问题
- java的引用类型所占用的内存空间
- JAVA 关于java中数据占用内存空间的大小
- 结构体占用内存空间的问题
- C++中结构体的内存空间占用
- Java对象占用内存空间的大小
- java输出程序本身占用的内存
- java中堆与栈 java中数据占用内存空间的大小
- Java中引用与内存空间分配
- 类占用的内存空间
- 类的内存空间占用
- 有趣的问题:空结构体的内存空间占用问题
- 【内存空间】01. 指针占用的内存空间大小
- 值类型变量所占用的内存空间位于线程堆栈中,而引用类型变量所引用的对象生存于托管堆中。
- Java SE 中 的 内存空间
- C语言结构体类型占用的内存空间问题。
- Makefile笔记
- Web开发中的Listener
- 设计模式之备忘录模式
- iOS开发中为整个App设置一个字体,但不指定字体大小的方法
- hadoop的Job相关功能
- JAVA中引用本身占用内存空间的问题
- Core Animation - 寄宿图<一>
- pull解析XML文件
- Java Exception——Java中的异常处理流程
- flash debug版本
- 杭电2063,最大配对
- Arduino自定义通信协议解析
- 多语言适配,让text自动改变大小
- XAML学习笔记1