java gc 随记
gc为garbage collection的缩写,中文翻译为垃圾回收。垃圾为不在使用的实例、变量,回收为释放垃圾所占用的内存空间。
学习过的C语言、C++语言,是没有垃圾回收机制的,因此需要软件工程师通过编写代码释放无用变量或实例占用的内存空间。人为操作会存在遗漏的问题,因此有时会出现内存泄露等问题。
jvm中的堆是主要的内存分配区域,jvm的gc工作区域也主要在这一片内存中。
如何判断哪些内存需要回收?
引用计数法
通过记录实例变量被引用的次数,可知不再使用的内存。但是如果存在交叉引用的情况,就会出现内存泄露的问题。
可达性分析法
通过一系列称为GC Roots的实例作为起点,逐步向下递归搜索各自引用的实例,搜索所走过的路径称为引用链。当一个实例不在GC Roots为起点的引用链时,证明此实例不再被使用,其内存空间可被回收。
GCRoots包含四个部分:
- 虚拟机栈本地变量表中引用的对象
- 方法区中类静态属性引用的对象
- 方法区中常量引用的对象
- 本地方法栈中JNI(Native方法)引用的对象
四种引用方式:强引用,软引用,弱引用,虚引用
如何垃圾回收?
标记-清除:两个阶段,会产生内存碎片。
标记-复制:内存空间分为两个部分,将标记后存活的实例复制到另一片内存空间中,另一片内存空间清空。
标记-整理:改变标记-清除算法的内存碎片问题,将存活实例整理在一起。
分代整理:分为年轻代内存空间和老年代内存空间,年轻代内存中的对象能存活下来的很少,使用标记-复制算法,年老代内存中的对象内存储下来的较多,使用标记-清除或标记-整理算法。
由谁执行垃圾回收?
serial收集器
使用单线程标记-复制算法进行垃圾回收,程序会暂停。
ParNew收集器
Serial收集器的多线程版本,程序依然会暂停。
Parallel Scavenge收集器
类似ParNew收集器,可动态调节垃圾回收时的停顿时间,吞吐量。程序依然暂停,但暂停时间可预估。
Serial Old收集器、Parallel Old收集器
单线程版、多线程版,标记-清除算法,程序会暂停
CMS收集器
分四个阶段
(1). 初始标记,标记GCRoots能直接关联到的对象,时间很短。程序暂停
(2). 并发标记,进行GCRoots Tracing(可达性分析)过程,时间很长。程序不暂停
(3). 重新标记,修正并发标记期间因用户程序继续运作而导致标记产生变动的那一部分对象的标记记录,时间较长。程序暂停
(4). 并发清除,回收内存空间,时间很长。程序不暂停
java gc 随记的更多相关文章
- Java GC回收机制
优秀Java程序员必须了解的GC工作原理 一个优秀的Java程序员必须了解GC的工作原理.如何优化GC的性能.如何与GC进行有限的交互,因为有一些应用程序对性能要求较高,例如嵌入式系统.实时系统等,只 ...
- 成为Java GC专家(3)—如何优化Java垃圾回收机制
为什么需要优化GC 或者说的更确切一些,对于基于Java的服务,是否有必要优化GC?应该说,对于所有的基于Java的服务,并不总是需要进行GC优化,但前提是所运行的基于Java的系统,包含了如下参数或 ...
- jvm系列(十):如何优化Java GC「译」
本文由CrowHawk翻译,是Java GC调优的经典佳作. 本文翻译自Sangmin Lee发表在Cubrid上的"Become a Java GC Expert"系列文章的第三 ...
- Java GC性能优化实战
GC优化是必要的吗? 或者更准确地说,GC优化对Java基础服务来说是必要的吗?答案是否定的,事实上GC优化对Java基础服务来说在有些场合是可以省去的,但前提是这些正在运行的Java系统,必须包含以 ...
- [面试] Java GC (未整理完)
Java GC简介 什么是 GC ? Java程序不用像C++程序在程序中自行处理内存的回收释放.这是因为Java在JVM虚拟机上增加了垃圾回收(GC)机制,用以在合适的时间触发垃圾回收. 你都了解哪 ...
- [转]Java GC的原理
Java GC(garbage collection,垃圾收集,回收) GC是对JVM中的内存进行标记和回收,Sun公司的JDK用的虚拟机都是HotSpot 对象化的实例是放在heap堆内存中的,这里 ...
- Java GC的原理
Java GC(garbage collec,垃圾收集,回收) GC是对JVM中的内存进行标记和回收,Sun公司的JDK用的虚拟机都是HotSpot 对象化的实例是放在heap堆内存中的,这里讲的分代 ...
- (转)Java GC基本算法
http://blog.csdn.net/heyutao007/article/details/38151581 1.引用计数(reference counting) 原理:此对象有一个引用,则 ...
- jvm系列(七):如何优化Java GC「译」
本文由CrowHawk翻译,地址:如何优化Java GC「译」,是Java GC调优的经典佳作. Sangmin Lee发表在Cubrid上的”Become a Java GC Expert”系列文章 ...
随机推荐
- C# WPF 开发随想
最近项目遇到切换窗口的时候偶尔出现闪屏的问题,前前后后花了两天的时间还是没有找到问题所在,一部分一部分的注释代码,看逻辑,开布局,还是一无所获. 最后还是他人的提醒下,直接不切换窗口,在同一个窗口中布 ...
- WordCount(JAVA实现)
201631103228,201631101227 1.项目需求 对程序设计语言源文件统计字符数.单词数.行数,统计结果以指定格式输出到默认文件中,以及其他扩展功能,并能够快速地处理多个文件. wc. ...
- 40. 组合总和 II leetcode JAVA
题目: 给定一个数组 candidates 和一个目标数 target ,找出 candidates 中所有可以使数字和为 target 的组合. candidates 中的每个数字在每个组合中只能使 ...
- 10分钟教你用VS2017将代码上传到GitHub
前言 关于微软的Visual Studio系列,真可谓是宇宙最强IDE了.不过,像小编这样的菜鸟级别也用不到几个功能.今天给大家介绍一个比较实用的功能吧,把Visual Studio 2017里面写好 ...
- POJ3349 Snowflake Snow Snowflakes (JAVA)
首先声明代码并没有AC,内存超了 但我对此无能为力,有没有哪位大神好心教一下怎么写 哈希,然后比较花瓣数组,这些应该都没问题才对..唉.. 贴MLE代码 import java.util.*; pub ...
- Netty 5 获取客户端IP(非HTTP)
使用Netty 5.0.0.Alpha2时,想知道客户端的ip以区分客户端,发现网上都是通过解析HTTP头域完成的,这里提供一种比较简单的方法. System.out.println("Cl ...
- 主流服务器虚拟化技术简单使用——Xen(二)
管理多台Xen主机可以使用GUI工具virt-manager和xm.xl等命令行工具. Tips:hypervisor一定要选到Xen web管理工具 Xen也有一个简易web管理工具叫xenwebm ...
- http-https php文件下载
http: function httpDownload($url, $path = '', $filename = '', $timeout = 60,$type = 0) { if ($url == ...
- 【Excel】数据字典制作
以下是设计的一种新的数据字典!!! 在Excle中新建2个sheet页,分别是:[主页]与[数据字典] 1.主页内容 E5对应的公式如下:=HYPERLINK("#'数据字典'!C" ...
- Caused by java.lang.IllegalStateException Not allowed to start service Intent { cmp=com.x.x.x/.x.x.xService }: app is in background uid UidRecord问题原因分析(二)
应用在适配Android 8.0以上系统时,会发现后台启动不了服务,会报出如下异常,并强退: Fatal Exception: java.lang.IllegalStateException Not ...