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”系列文章 ...
随机推荐
- poj 3468 A Simple Problem with Integers 线段树区间加,区间查询和(模板)
A Simple Problem with Integers Time Limit: 1 Sec Memory Limit: 256 MB 题目连接 http://poj.org/problem?i ...
- 关于C# 向TIM或者QQ自动发送中文消息【微信也是可用的】 附测试GIF中微信可用的 全新修订
在上一篇文章的代码 对于微信已失效 重新更新一边 效果图: 源代码 using System; using System.Runtime.InteropServices; using System.T ...
- VMware Workstation内存不足问题的解决!
我今天使用VMware Workstation,遇到内存使用不足的问题,我使用的VMware Workstation是9,刚开始我以为是我的VMware Workstation版本低,所以上网找到了V ...
- lua luna工具库
luna工具库 概述 luna库提供了几个lua开发的常见辅助功能: lua/c++绑定 lua序列化与反序列化 变长整数编码,用于lua序列化,当然也可以方便的用于其他场合 这里把代码编译成了动态库 ...
- 2.iptables 匹配条件(基础)
基本匹配条件 -s 用于匹配报文的源地址,可以同时指定多个源地址,每个IP地址用逗号分开,也可以指定网段 iptables -t filter -I INPUT -s 192.168.1.111,19 ...
- CSS动态定位
$(document).ready(function(){ $('body').on('click', '#start_timer', function() { var laydate = $(&qu ...
- React.Children详解
React.Children提供了处理this.props.children的工具,this.props.children可以任何数据(组件.字符串.函数等等).React.children有5个方法 ...
- 对java的理解
一门编程语言,分三部分. 核心语法,库,数据结构.
- linux使用curl命令行进行接口测试
cURL介绍cURL 是很方便的Rest客戶端,可以很方便的完成许多Rest API测试的需求,甚至,如果是需要先登入或认证的rest api,也可以進行测试,利用curl指令,可以送出HTTP GE ...
- Django项目使用七牛云存储图片
Django项目使用七牛云存储图片 最近,写了一个django项目,想在项目中使用七牛云存储上传图片,在网上搜索到django-qiniu-storage,查看文档,按步骤居然设置成功了. 安装 1 ...