Loading

JVM初探

### JVM分为类的加载生命周期和gc垃圾回收两个大的方面
#####首先是类的生命周期,
类的加载:
--> 记载字节码 ---> 这个过程有类的加载起参与,双亲委托机制()
--> 验证字节码 ---> 确保加载的类信息符合JVM规范,没有安全方面的问题
--> 准备 ---> 正式为类变量(static变量)分配内存并设置类变量初始值的阶段,这些内存都将在方法去中进行分配
--> 解析 ---> 虚拟机常量池的符号引用替换为字节引用过程
--> 初始化
---> 初始化阶段是执行类构造器<clinit>()方法的过程。类构造器<clinit>()方法是由编译器自动收藏类中的所有类变量的赋值动作和静态语句块(static块)中的语句合并产生
---> 当初始化一个类的时候,如果发现其父类还没有进行过初始化,则需要先触发其父类的初始化
---> 虚拟机会保证一个类的<clinit>()方法在多线程环境中被正确加锁和同步
---> 当范围一个Java类的静态域时,只有真正声名这个域的类才会被初始化

--> 使用 ---> 正常调用
--> 卸载 ---> 等待gc回收

#### Java中,栈的大小通过-Xss来设置,当栈中存储数据比较多时,需要适当调大这个值,否则会出现java.lang.StackOverflowError异常。
#### 在Java中,一个空Object对象的大小是8byte(new Object), 因为所有的Java非基本类型的对象都需要默认继承Object对象,
#### 因此不论什么样的Java对象,其大小都必须是大于8byte。


## GC
标记-清除(Mark-Sweep):
`此算法执行分两阶段。第一阶段从引用根节点开始标记所有被引用的对象,第二阶段遍历整个堆,把未标记的对象清除。此算法需要暂停整个应用,同时,会产生内存碎片。`
复制(Copying):
`此算法把内存空间划为两个相等的区域,每次只使用其中一个区域。垃圾回收时,遍历当前使用区域,把正在使用中的对象复制到另外一个区域中。
此算法每次只处理正在使用中的对象,因此复制成本比较小,同时复制过去以后还能进行相应的内存整理,不会出现“碎片”问题。
当然,此算法的缺点也是很明显的,就是需要两倍内存空间。`
标记-整理(Mark-Compact):
`此算法结合了“标记-清除”和“复制”两个算法的优点。也是分两阶段,第一阶段从根节点开始标记所有被引用对象,第二阶段遍历整个堆,
把清除未标记对象并且把存活对象“压缩”到堆的其中一块,按顺序排放。此算法避免了“标记-清除”的碎片问题,同时也避免了“复制”算法的空间问题。`

## 引用类型
`对象引用类型分为强引用、软引用、弱引用和虚引用。`
强引用:就是我们一般声明对象是时虚拟机生成的引用,强引用环境下,垃圾回收时需要严格判断当前对象是否被强引用,如果被强引用,则不会被垃圾回收
软引用:软引用一般被做为缓存来使用。与强引用的区别是,软引用在垃圾回收时,虚拟机会根据当前系统的剩余内存来决定是否对软引用进行回收。
弱引用:弱引用与软引用类似,都是作为缓存来使用。但与软引用不同,弱引用在进行垃圾回收时,是一定会被回收掉的,因此其生命周期只存在于一个垃圾回收周期内。

posted @ 2019-05-07 11:59  书中人007  阅读(271)  评论(0编辑  收藏  举报
拈花微笑·恬淡诠释生命