JVM之GC(一)
Java较C而言,最大的区别在于内存管理。JVM设有无用内存空间自动回收复用机制,也就是我们所说的GC。
之前说过,栈是为线程、为函数的执行分配内存的地方,用完即“销毁”,这里留待以后做深入探讨;堆是为对象和数组分配内存的地方,有些对象可能会伴随着程序运行的完整生命周期,但大部分对象都是朝生夕死的,如何判断对象是否有必要“占坑”呢?首先我们要来说一下判别方法:Java中对象的活性判别主要有两种,引用计数法和可达性分析法。
引用计数法:为每个对象设立一个计数器,对象每被引用一次,计数器加一,当引用失效的时候,计数器减一。原理简单易懂,但存在一个致命问题,无法处理循环引用问题。如果A.son = B; B.son = A;A和B除此之外再无其他引用,按需求A和B应该被回收掉,但引用计数法却无法识别这种引用。
可达性分析法:JVM列出一些称之为GC Roots的对象,把它们作为活对象的源头,如果顺着它们的引用能找到的对象,一律认为是活着的。那么哪些对象可以当作GC Roots呢?能作为GC Roots的对象,一定是程序目前运行中的正在使用的对象。JVM规定了以下四类:
1、栈里面的本地变量表中,引用类型所指向的对象;
2、本地方法栈中Native方法所引用的对象;
3、方法区中常量所指向的对象;
4、方法区中类的静态属性所指向的对象
针对上述两种方法,都存在一个共有名词:引用!如果只存在一种引用,非黑即白,那么Java也太不智能了。所以,Java中把引用分为四个等级,有强有弱,依次分为:
强引用:我们最常见的引用类型,类似于User user = new User();强引用是真的引用!
软引用:当JVM申请不到额外内存了,快到内存溢出时,会把软引用的对象处理掉腾出空间;SoftReference类
弱引用:通过弱引用关联的对象只能活到下次GC之前;WeakReference类
虚引用:这种引用连最基本的调用都无法实现,仅仅用来为对象发送GC通知。PhantomReference类
finalize方法
对于那些不可达的对象,也不是不给它们申辩机会的。当JVM发现程序不可达后,会对这个对象进行一次标记,此时对象如果重写了finalize方法,JVM会把它扔进F_Queue的队列之中,并在之后创建一个低优先级的Finalizer线程去触发这个对象的finalize方法。JVM 会对队列中的对象进行第二次标记,如果在执行方法之后,这个对象成功与活着的对象产生引用关联,那么他将被移除这个队列,对象成功拯救了自己。如果没有重写finalize方法或者没能取得引用关联,下次GC的时候它就真的会被回收掉了。
但是不建议使用这个方法来干预JVM的GC过程,因为代价高昂,不确定性大,finalize方法能做的事情在try finally中都可以做得更好更及时。
方法区回收
栈、堆、方法区是三个占用内存最大的地方,其中对堆区进行GC最高效,对方法区GC情况就很不乐观了。方法区在一些JVM中又叫永久代,他们不会对方法区进行GC操作。
方法区是用来存放类信息的地方,这里可以把常量池中无用常量和无用类回收掉。
常量回收:如果一个字面量没有对象引用它,如“abc”,那么就可以把它清理出常量池了。
类回收:当一个类1、所有实例都被已经回收掉 2加载该类的classLoader已经被回收; 3、该类对应的java.lang.Class对象没有任何地方被引用,无法在任何地方通过反射访问该类的方法,满足这三个条件的类就可以清理掉了,条件很苛刻,但是满足这三点的类也不是说一定会被清理,而是通过参数来控制。如果你的程序大量使用了动态生成class(反射,动态代理,动态生成jsp等),以及大量自定义classLoader(OSGi)的场景,可以设置类卸载的功能来防止方法区溢出。
JVM之GC(一)的更多相关文章
- JVM的GC概述
JVM的GC概述 GC即垃圾回收,是指jvm用于释放那些不再使用的对象所占用的内存.在充分理解了垃圾收集算法和执行过程后,才能有效的优化它的性能. 有些垃圾收集专用于特殊的应用程序.比如,实时应用程序 ...
- Linux使用jstat命令查看jvm的GC情况
Linux使用jstat命令查看jvm的GC情况 http://www.open-open.com/lib/view/open1390916852007.html http://www.aiuxian ...
- poptest老李谈jvm的GC
poptest老李谈jvm的GC poptest是国内唯一一家培养测试开发工程师的培训机构,以学员能胜任自动化测试,性能测试,测试工具开发等工作为目标.如果对课程感兴趣,请大家咨询qq:90882 ...
- Linux使用jstat命令查看jvm的GC情况(转)
B. jstack jstack主要用来查看某个Java进程内的线程堆栈信息.语法格式如下: 1 jstack [option] pid 2 jstack [option] executable co ...
- jvm的GC日志分析 [转]
jvm的GC日志分析 标签: jvm内存javagc 2015-06-22 16:37 1566人阅读 评论(1) 收藏 举报 分类: Java(4) JVM的GC日志的主要参数包括如下几个: ...
- JVM 的GC算法和垃圾收集器
1.标记清除算法 黑色部分代表可回收对象,灰色部分代表存活对象,绿色部分代表未使用的.最基础的收集算法就是标记清除算法如同他名字一样,算法分为"标记"和"清除" ...
- JVM&G1 GC 学习笔记(一)
在入门学习JVM的过程中,我们需要先了解关于JVM的知识中有哪些关键词或关键术语,今天在看完书后我想记录下来. Xms64mb 虚拟机初始化时设置内存大小为64mb Xmx256mb 设定虚拟 ...
- 深入理解JVM+G1+GC.pdf (中文版带书签)
目录 序 VII前言 IX 第1章 JVM & GC基础知识 11.1 引言 21.2 基本术语 31.2.1 Java相关术语 41.2.2 JVM/GC通用术语 241.2.3 G1涉及术 ...
- JVM之GC(二)
昨天总结了GC之前要做的事情,今天介绍一下主流的GC算法. 先介绍一下几个名词: Stop The World(STW):JVM进行GC的时候总不能一边清理垃圾一边制造垃圾把,那么垃圾鉴定的准确性根本 ...
随机推荐
- Java反射机制(二):通过反射取得类的结构
在反射运用过程中,如果你想得到一个类的完整结构,那么就要使用到java.lang.reflect包中的几个类: · Constructor 表示类中的构造方法 · Field 表示类中的属性 · ...
- Python--day68--ORM内容回顾
Django项目如何使用ORM连接MySQL: 多对多关系讲解:
- 洛谷P5020 货币系统 题解 模拟
题目链接:https://www.luogu.org/problem/P5020 这道题目是一道模拟题,但是又有一点多重背包的思想在里面. 首先我们定义一个 vis[i] 来表示和为 i 的情况在之前 ...
- no_expand优化案例
bond 来看一个烂语句: select a.*,b.dn from temp_allcrmuser a, phs_smc_user b where a.USERNUMBER=b.dn and ( ...
- P1043 查找小于x的最大元素
题目描述 现在告诉你一个长度为 \(n\) 的有序数组 \(a_1, a_2, ..., a_n\) ,以及 \(q\) 次询问,每次询问会给你一个数 \(x\) ,对于每次询问,你需要输出数组 \( ...
- vue的路由带参数和取参数,watch路由监听
1.写在html里 <router-link :to="{path:'/goldShop/goodsInfo',query: { id:item.id }}" class=& ...
- H3C开启telnet服务
[H3C]Telnet server enable //开启telnet服务
- javascript 闭包的理解(二)
// 定义一个User构造函数 function User(properties){ //遍历对象属性,确保它作用域正确 for(var i in properties){ (function(whi ...
- Jmeter配置元件——JDBC Connection Configuration参数化
在昨天Jmeter配置元件——CSV DataSet Config参数化一文中,有提到,在参数化时,还可以使用JDBC Connection Configuration配置元件实现,具体如何实现,如何 ...
- 谈谈模型融合之一 —— 集成学习与 AdaBoost
前言 前面的文章中介绍了决策树以及其它一些算法,但是,会发现,有时候使用使用这些算法并不能达到特别好的效果.于是乎就有了集成学习(Ensemble Learning),通过构建多个学习器一起结合来完成 ...