标签分类
当前位置:首页 > 人工智能电子书 > 算法电子书网盘下载
垃圾回收算法手册:自动内存管理的艺术 垃圾回收算法手册:自动内存管理的艺术
HelloKitty

HelloKitty 提供上传

资源
38
粉丝
17
喜欢
180
评论
14

    垃圾回收算法手册:自动内存管理的艺术 PDF 高清版

    算法电子书
    • 发布时间:

    给大家带来的一篇关于算法相关的电子书资源,介绍了关于垃圾回收算法、自动内存管理方面的内容,本书是由机械工业出版社出版,格式为PDF,资源大小119.2 MB,理查德·琼斯编写,目前豆瓣、亚马逊、当当、京东等电子书综合评分为:9.9,更多相关的学习资源可以参阅 人工智能电子书、等栏目。

  • 垃圾回收算法手册:自动内存管理的艺术 PDF 下载
  • 下载地址:https://pan.baidu.com/s/10ukbcey9pf65loYF-Hcq8A
  • 分享码:xoz4
  • 垃圾回收算法手册:自动内存管理的艺术 PDF

    基本上全部的当代计算机语言都选用了垃圾回收体制,因而深层次掌握此层面內容针对全部开发人员来讲都大有益处。针对不一样垃圾回收器的工作中方法,及其当今垃圾回收器所遭遇的各种各样难题,这产品说明书都出示了技术专业的解释。把握这行的专业知识以后,在应对多种的垃圾回收器及其各种各样调整选择项时,坚信开发人员可以更没把握。

    这书共19章,第1章讨论为何必须自动内存管理,并简略详细介绍对不一样垃圾回收对策开展较为的方式;第2~5章详细说明4种經典的垃圾回收算法,包含标识-清理算法、标识-梳理算法、拷贝式回收算法和引证记数算法;第6章深层次较为第2~5章所详细介绍的回收对策与算法;第7章详细介绍多种的运行内存分派技术性,并深化研究全自动垃圾回收与显示信息内存管理这二种情景下分派对策的不同点;第8章探讨为什么必须将堆区划为好几个不一样的室内空间,及其怎么管理这种室内空间;第9章详细介绍分代垃圾回收;第10章详细介绍大另一半的管理模式及其别的系统分区对策;第11章详细介绍运作时插口,包含表针搜索、可以安*进行垃圾回收的编码部位、读写能力天然屏障等;第12章探讨特殊語言有关內容,包含结束体制和弱引证;第13章讨论当代硬件系统给垃圾回收器的保持者所产生的新挑战和机遇,一起详细介绍同歩、前行、完毕、相同等难题的有关算法;第14章详细介绍怎样在脱机全部手机应用程序进程的前提条件下应用好几个进程开展垃圾回收;第15~18章详细介绍多种类型的高并发回收器;第19章讨论垃圾回收在硬即时系统软件中的运用。

    目录

    • 第1章 引言 1
    • 第2章 标记–清扫回收 15
    • 第3章 标记–整理回收 28
    • 第4章 复制式回收 38
    • 第5章 引用计数 49
    • 第6章 垃圾回收器的比较 64
    • 第7章 内存分配 72
    • 第8章 堆内存的划分 87
    • 第9章 分代垃圾回收 95
    • 第10章 其他分区策略 117
    • 第11章 运行时接口 138
    • 第12章 特定语言相关内容 188
    • 第13章 并发算法预备知识 202
    • 第14章 并行垃圾回收 242
    • 第15章 并发垃圾回收 271
    • 第16章 并发标记–清扫算法 285
    • 第17章 并发复制、并发整理算法 298
    • 第18章 并发引用计数算法 322
    • 第19章 实时垃圾回收 333

    上一篇:Android外设开发实战  下一篇:jQuery EasyUI开发指南

    展开 +

    收起 -

    算法相关电子书
    学习笔记
    网友NO.986679

    JVM的垃圾回收算法工作原理详解

    怎么判断对象是否可以被回收? 共有2种方法,引用计数法和可达性分析 1.引用计数法 所谓引用计数法就是给每一个对象设置一个引用计数器,每当有一个地方引用这个对象时,就将计数器加一,引用失效时,计数器就减一。当一个对象的引用计数器为零时,说明此对象没有被引用,也就是“死对象”,将会被垃圾回收. 引用计数法有一个缺陷就是无法解决循环引用问题,也就是说当对象A引用对象B,对象B又引用者对象A,那么此时A,B对象的引用计数器都不为零,也就造成无法完成垃圾回收,所以主流的虚拟机都没有采用这种算法。 public classReferenceFindTest{publicstaticvoidmain(String[] args){MyObject object1 = new MyObject();MyObject object2 = new MyObject();object1.object = object2;object2.object = object1;object1 = null;object2 = null;}} 2.可达性算法(引用链法) 该算法的思想是:从一个被称为GC Roots的对象开始向下搜索,如果一个对象到GC Roots没有任何引用链相连时,则说明此对象不可用。 在java中可以作为GC Roots的对象有以下几种: 虚拟机栈中引用的对象 方法区类静态属性引用的对象 方法区常量池引用的对象 本地方法栈JNI引用的对象 虽然这些算法可以判定一个对象是否能被回收,但是当满足上述条件时,一个对象比不一定会被回收。当一个对象不可达GC Root时,这个……

    网友NO.904830

    Java垃圾回收之复制算法详解

    之前的Java垃圾回收之标记清除算法详解 会导致内存碎片。下文的介绍的coping算法可以解决内存碎片问题。 概述 如果jvm使用了coping算法,一开始就会将可用内存分为两块,from域和to域, 每次只是使用from域,to域则空闲着。当from域内存不够了,开始执行GC操作,这个时候,会把from域存活的对象拷贝到to域,然后直接把from域进行内存清理。 应用场景 coping算法一般是使用在新生代中,因为新生代中的对象一般都是朝生夕死的,存活对象的数量并不多,这样使用coping算法进行拷贝时效率比较高。 jvm将Heap 内存划分为新生代与老年代,又将新生代划分为Eden(伊甸园) 与2块Survivor Space(幸存者区) ,然后在Eden –Survivor Space 以及From Survivor Space 与To Survivor Space 之间实行Copying 算法。 不过jvm在应用coping算法时,并不是把内存按照1:1来划分的,这样太浪费内存空间了。一般的jvm都是8:1。也即是说,Eden区:From区:To区域的比例是 8:1:1 始终有90%的空间是可以用来创建对象的,而剩下的10%用来存放回收后存活的对象。 1、当Eden区满的时候,会触发第一次young gc,把还活着的对象拷贝到Survivor From区;当Eden区再次触发young gc的时候,会扫描Eden区和From区域,对两个区域进行垃圾回收,经过这次回收后还存活的对象,则直接复制到To区域,并将Eden和From区域清空。 2、当后……

    网友NO.981927

    Java垃圾回收之分代收集算法详解

    概述 这种算法,根据对象的存活周期的不同将内存划分成几块,新生代和老年代,这样就可以根据各个年代的特点采用最适当的收集算法。可以用抓重点的思路来理解这个算法。 新生代对象朝生夕死,对象数量多,只要重点扫描这个区域,那么就可以大大提高垃圾收集的效率。另外老年代对象存储久,无需经常扫描老年代,避免扫描导致的开销。 新生代 在新生代,每次垃圾收集器都发现有大批对象死去,只有少量存活,采用复制算法,只需要付出少量存活对象的复制成本就可以完成收集;可以参看我之前写的Java垃圾回收之复制算法详解 老年代 而老年代中因为对象存活率高、没有额外空间对它进行分配担保,就必须“标记-清除-压缩”算法进行回收。参看Java垃圾回收之标记压缩算法详解 新创建的对象被分配在新生代,如果对象经过几次回收后仍然存活,那么就把这个对象划分到老年代。 老年代区存放Young区Survivor满后触发minor GC后仍然存活的对象,当Eden区满后会将存活的对象放入Survivor区域,如果Survivor区存不下这些对象,GC收集器就会将这些对象直接存放到Old区中,如果Survivor区中的对象足够老,也直接存放到Old区中。如果Old区满了,将会触发Full GC回收整个堆内存。 永久代:(即方法区回收) JVM的方法区,也被称为……

    网友NO.671289

    Java垃圾回收之标记清除算法详解

    java垃圾回收算法之-引用计数器,这个算法其中一个优点便是,实时性,只要对象的引用计数器的值为0,则立刻回收。接下来介绍的标记清除算法,当对象的引用计数器的值为0时,不会立刻被回收的。 概念介绍 root对象 在标记清除算法中,会把如下对象称之为root对象 被栈中的变量(栈中存的是对象的引用)所引用的对象 被static变量引用的对象 可访问的对象 如果栈中有一个变量a引用了一个对象,那么该对象是可访问的,如果该对象中的某一个字段引用了另一个对象b,那么b也是可访问的。可访问的对象也称之为 live 对象 标记清除算法介绍 该算法有两个阶段。 1. 标记阶段:找到所有可访问的对象,做个标记 2. 清除阶段:遍历堆,把未被标记的对象回收 备注: 该算法一般应用于老年代,因为老年代的对象生命周期比较长。 标记阶段算法 伪代码类似如下: for each root variable r mark (r);sweep (); 为了能够区分对象是live的,可以为每个对象添加一个marked字段,该字段在对象创建的时候,默认值是false 假设有一个对象p,p对象还间接的引用了其他对象,那么可以使用一个递归算法去进行标记,例如: void mark(Object p) if (!p.marked) p.marked = true; for each Object q referenced by p mark (q); 这个mark方法只有当所有对象已经被mark后才会退出。 清除阶段算……

    Copyright 2018-2019 xz577.com 码农之家

    版权责任说明