Anroid内存笔记 -- 内存及GC概念

Java内存区域

Java虚拟机在执行Java程序时, 会把管理的内存, 分为几个区域;
平时我们一般粗略的分成栈和堆; 栈存放对象引用指针, 堆则存放栈中指针指向的对象;

Java虚拟机栈

  1. 线程私有, 生命周期和Thread相同;
  2. 虚拟机栈描述的是Java方法执行的内存模型: 每个方法执行时,都会创建一个栈帧, 用于存储局部变量表,操作数栈,动态链接,方法出口等信息;每一个方法执行,都对应一个栈帧在虚拟机栈中入栈到出栈;
  3. 平时我们说的栈,即局部变量表; 它存放了编译器可知的各种基本数据类型, 和对象引用等

Java堆

  1. Java堆是被所有线程共享内存区域, 在虚拟机启动时创建;
  2. 用来存放对象实例, 几乎所有的对象实例和数组都在此分配内存;
  3. Java堆是内存回收的主要区域,很多时候称之为GC堆

方法区

  1. 各个线程共享的内存区域
  2. 用来存放被虚拟机加载的类信息,常量,静态变量,编译器编译后的代码等
  3. 也称之为Non-Heap(非堆), 自己程序开发一般不关注 - -

垃圾收集器

gc收集时, 需要完成3件事:

  1. 哪些内存需要回收
  2. 什么时候回收
  3. 如何回收

判断那些内存需要回收

回收时,肯定要确定哪些对象要被回收,要判断哪些对象已死(即不可达);

引用计数法

给对象一个引用计数器, 每当一个地方引用它时, 计数器加1; 当引用失效时, 计数器减1; 任何时候计数器为0的对象, 即不可达对象, 可被回收;
引用技术简单, 但遇见相互引用时, 无法判定; eg, A引用B, B同时引用A, A和B都不再有其他任何引用, 实际对象不可访问, 但是引用计数器却不为0;

可达性分析

通过一系列GC Root对象作为起点, 从这些节点向下搜索,搜索走过的路径称之为引用链, 当一个对象到GC Root没有任何引用链来连接时, 则此对象不可达, 可以用来回收;
而用来作为GC Root的对象有下面几种:

  1. 虚拟机栈,即本地变量表中引用的对象
  2. 方法区中静态属性引用的对象
  3. 方法区中常量引用的对象
  4. 本地方法栈JNI, 即Native方法引用的对象

垃圾收集算法

标记-清除算法

Mark-Sweep算法,如同名称一样, 分标记和清楚两步: 首先标记出需要回收的对象, 在标记完成后, 统一回收所有被标记的对象;
主要有2个不足: 一是效率, 标记和清除效率都不高; 二是空间问题, 清除后会产生大量的不连续的内存碎片, 空间碎片太多,可能导致程序运行时, 需要分配较大内存的对象时, 无法找到足够的连续内存而不得不在一次触发gc;

复制算法

为了解决效率问题, Copying的收集算法出现了, 将内存分为容量相等的两块, 每次只使用其中一块, 当一块内存用完时, 就将还存活着的对象复制到另一块上去, 然后把已使用过的内存一次清理;

标记-整理算法

先需要从根节点开始对所有可达对象做一次标记,但之后,它并不简单地清理未标记的对象,而是将所有的存活对象压缩到内存的一端。之后,清理边界外所有的空间。这种方法既避免了碎片的产生,又不需要两块相同的内存空间;

分代收集算法

将所有的新建对象都放入称为年轻代的内存区域,年轻代的特点是对象会很快回收,因此,在年轻代就选择效率较高的复制算法。当一个对象经过几次回收后依然存活,对象就会被放入称为老生代的内存空间。对于新生代适用于复制算法,而对于老年代则采取标记-整理,或者标记-清除算法

垃圾收集器

收集器是真正实现收集算法的地方,有各种版本, 主要说下CMS

CMS收集器

Concurrent Mark Sweep, 名称可以看出是基友标记-清除算法的收集器; 为了使用回收停顿时间(Stop The World`)最短为目标的收集器;
工作流程分为下面几个步骤:

  1. 初始标记, CMS initial mark
  2. 并发标记, CMS concurrent mark
  3. 重新标记, CMS remark
  4. 并发清楚, CMS concurrent sweep

其中,初始标记和重新标记需要Stop The World. 初始标记仅标记GC Root能直接关联的对象; 并发标记即进行初始标记后的引用可达遍历; 重新标记则是修正并发标记期间程序继续运行而导致标记变动的对象;

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 219,427评论 6 508
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 93,551评论 3 395
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 165,747评论 0 356
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,939评论 1 295
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,955评论 6 392
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,737评论 1 305
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,448评论 3 420
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,352评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,834评论 1 317
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,992评论 3 338
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 40,133评论 1 351
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,815评论 5 346
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,477评论 3 331
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 32,022评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 33,147评论 1 272
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 48,398评论 3 373
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 45,077评论 2 355

推荐阅读更多精彩内容

  • 原文阅读 前言 这段时间懈怠了,罪过! 最近看到有同事也开始用上了微信公众号写博客了,挺好的~给他们点赞,这博客我...
    码农戏码阅读 5,979评论 2 31
  • 1.什么是垃圾回收? 垃圾回收(Garbage Collection)是Java虚拟机(JVM)垃圾回收器提供...
    简欲明心阅读 89,507评论 17 311
  • 这篇文章是我之前翻阅了不少的书籍以及从网络上收集的一些资料的整理,因此不免有一些不准确的地方,同时不同JDK版本的...
    高广超阅读 15,614评论 3 83
  • 《深入理解Java虚拟机》笔记_第一遍 先取看完这本书(JVM)后必须掌握的部分。 第一部分 走近 Java 从传...
    xiaogmail阅读 5,097评论 1 34
  • JVM架构 当一个程序启动之前,它的class会被类装载器装入方法区(Permanent区),执行引擎读取方法区的...
    cocohaifang阅读 1,667评论 0 7