Java堆
特点:
- Java堆是虚拟机所管理的内存中最大的一块内存区域
- 他是所有线程共享的内存区域
- 它的生命周期会随着虚拟机的启动而创建,关闭而销毁
- 在Java世界中,几乎所有的对象实例都在这里分配内存
- 它被实现的时候,可以被定义为固定大小的,也可以被定义为可扩展的,当前主流都是可扩展的(通过**-XMS和-XMX**设定)
- 它可以分为很多区域,比如新生代、老年代、永久代,无论分多少个区域其存储的对象只会是实例对象,而创建这些区域的目的是为了更好的进行内存回收
垃圾收集器
Java堆也是垃圾收集器管理的内存区域,因此一些资料中它也被称作 “GC堆”
从回收内存的角度看,由于先到垃圾收集器大部分都是基于分代收集理论设计的,所以java堆中经常会出现新生代、老年代、永久代、Eden空间、From Survivor空间、To Survivor空间等名词。而非某个Java虚拟机具体实现的固有内存布局,这些区域划分仅仅是一部分垃圾收集器的共同特性或者设计风格而已。
分配内存
如果从分配内存的角度看,所有线程共享Java堆中可以划分出多个线程私有的分配缓冲区,以提升对象分配时的效率,无论怎么划分都不会改变java堆中存储内容的共性,那就是无论哪个区域,存储的都只能是对象实例,将java堆细分的目的只是为了更好地回收内存,或者更快的分配内存
Java堆可以处于物理上不连续的内存空间中,但逻辑上必须是连续的,但对于大对象(典型的如数组对象),多数虚拟机实现处于简单、存储高效的考虑,很可能会要求连续的空间。
OutOfMemoryError异常
如果在Java堆中没有内存没有完成实例分配,并且堆再也无法扩展时,Java虚拟机将会抛出OutOfMemoryError异常