标签:jvm
java堆图解:类加载子系统:负责从文件或网络加载class信息,存放在方法区的内存空间中。
方法区:存放类信息、常量信息、常量池信息、包括字符串和数字常量
java方法区和堆一样,方法区是一块所有线程共享的内存区域,它保存系统的类信息,比如类的字段。方法区的大小决定了系统可以保存多少个类,如果系统定义太多的类,导致方法区溢出。虚拟机同样会抛出内存溢出错误。方法区可以理解为“”永久区“”(Perm)
堆:在java虚拟机启动的时候建立堆,它是java程序最主要的内存工作区域,几乎所有的对象实例都存放到java堆中,堆空间是所有线程共享的
直接内存:java的NIO库允许java程序使用直接内存,从而提高性能,通常直接内存速度会优于java堆。读写频繁的场合可能会考虑使用
栈:每个虚拟机线程都有一个私有的栈,一个程序的java栈在线程创建的时候被创建,java栈中保存着局部变量、方法参数、同时java的方法调用、返回值等
局部变量表:用于报错函数的参数及局部变量
操作数栈:主要保存计算过程的中间结果,同时作为计算过程中变量临时的存储空间
帧数据区:除了局部变量表和操作数栈以外,栈还需要一些数据来支持常量池的解析,这里帧数据区保存
着访问常量池的指针,方便程序访问常量池,另外,当函数返回或出现异常时,虚拟机必须有一个异常处理表
方便发送异常的时候找到异常的代码,因此异常处理表也是帧数据区的一部分
垃圾收集算法(核心算法,其他算法略)
复制算法:其核心思想就是将内存空间分为2块,每次只使用其中1块,在垃圾回收时,将正在使用的内存中的存留
对象复制到未被使用的内存块中去,之后去除之前正在使用的内存块中所有的对象,反复去交换2个内存
的角色,完成垃圾收集(java中新生代的from和to空间就是使用的这个算法)
标记压缩法:标记压缩法在标记清除法的基础上做优化,把存活的对象压缩到内存一端,而后进行垃圾清理(java老年代使用的这个算法)
分代算法:根据对象的特点把内存分成n块,而后根据每个内存的特点使用不同的算法、
对于新生代和老年代来说,新生代回收率很高,但是每次回收耗时很短,老年代回收率低,耗时较长,所以应该尽量减少老年代的GC
分区算法:将整个内存分为n多个小的独立空间,每个小的空间可以独立使用,细粒度的控制每一个空间,而不是对整个空间进行GC,从而提高性能,减少GC的停顿
标签:jvm
原文地址:http://blog.51cto.com/9695005/2053823