GC --编程员的福利
来源:互联网 发布:阿里云 贴吧签到 编辑:程序博客网 时间:2024/04/29 04:10
一 什么是GC
说道JVM,就不得不说GC,垃圾回收机制在JVM中占有很重要的比重。在JVM运行的时候如果不进行垃圾回收,可想而知,再大的内存也会有满的一天,而且GC的出现不需要我们自己管理内存,有JVM定时的检查,将无用的对象回收,这样对我们的编码带来很大的便利!
二 GC是怎么工作
GC通过一定的算法 ,在JVM运行的时候定时的去检查内存空间,然后根据一定的算法对无用的对象进行回收。这里回收的位置主要是java堆,本身java对就是保存对象的地方,占用内存的绝大部分的空间,通过回收机制,有的对象被回收,但是对象因为引用还存在,进过回收机制不能被回收,经过多次这样的回收,仍然存在java堆中的对象会被保存在老年代。这里我们可以清楚的知道,来及回收机制回收的是java堆的新生代。
三 对象引用类型:
1.强引用:Reference:普通类型的引用
2.软引用:SoftReference,被软引用引用的对象,如果此对象没有被其他强Reference应用的话,很容易被回收,但是通常是在内存数不够的时候,并且被程序抛出OutMemoryError之前才发生对此对象的GC,SoftReference通常被用作实现Cache的对象引用,如果这个对象被GC了,那么他可以在任何时候再重新创建。此外。软引用还有一个非常经典的用途就是用于敏感的告诉缓存。
3.弱引用:WeekReference,这种引用,如果此外还没有强引用或是软引用,会立刻被回收。弱引用一个典型的用图就是规范化映射。
4.虚引用:PhantomReference,当没有强引用,软引用,弱引用的时候回立刻被回收,但是当与队列联合使用的时候,需要管理和清除与被引用的对象的相关的本地资源。
四 GC算法
1.GC算法分类:
(1)引用计数法
(2)标记清除法
(3)标记压缩法
(4)复制算法
2.分析各种算法
(1)引用计数法:给对象添加一个引用计数器,每当有一个地方引用它时,计数器值加1,当引用失效时,计数器值就减1;任何时刻计数器为0的对象是不可能被使用的。引用计数法效率很高,但是很难解决对象之间相互循环引用的问题。此外,引用和去引用伴随的加减法影响性能,循环引用的对象无法回收。
(2)标记-清除法:分为两个阶段:标记阶段和清除阶段。一种可行的实现是:在标记阶段,首先通过根节点,标记所有从根节点开始的可达对象,未被标记的对象就是未被引用的来及对象,然后在清除阶段清除所有未被标记的对象。
(3) 标记压缩:适合于存活对象较多的场合,如老年代。对于可达对象做一次标记,然后对所有的存活对象压缩到内存的异端,然后清理边界空间。
(4)复制算法:适合于新生代,是一种比较高效的回收算法。将原有的内存空间分为两块,每次只使用其中一块儿,在垃圾回收时,将正在使用的内存中的存活对象复制到未使用的内存块儿中,之后清除正在使用的内存块儿中的所有对象,交换两个内存的角色,完成垃圾回收。
0 0
- GC --编程员的福利
- 《编程员的生活》
- 编程界的福利
- 超级编程员的品质
- 编程员的三大美德
- 黑马编程员--函数的基本知识总结
- 面对GC的java编程
- 面向GC的Java编程
- 面向GC的Java编程
- 面向GC的Java编程
- 面向GC的Java编程
- 面向GC的Java编程
- 面向GC的Java编程
- 面向GC的Java编程
- 面向GC的Java编程
- 面向GC的Java编程
- 面向GC的Java编程
- GC(GC友好编程)
- PopupWindow进出动画
- 彩印包装印刷行业erp-轻松、易用
- 常见问题总结篇三、 IOS绘制 1 像素边框
- 快速排序实现
- 数据库事务隔离级别
- GC --编程员的福利
- CodeSmith7安装包+破解工具(DLL/BLL/ENTITY生成工具)
- android log 抓取
- HTML 5 <input> placeholder
- Android 常用第三方组件
- View的绘制
- Media Data之多媒体扫描过程分析(一)
- HDU-1097-A hard puzzle(快速幂)
- 382. Linked List Random Node