传统的C/C++等编程语言,需要程序员负责回收已经分配的内存。显示进行垃圾回收是一件比较困难的事情,因为程序员并不总是知道内存应该何时被释放。如果一些分配出去的内存得不及时回收,就会引起系统运行速度下降,甚至导致程序瘫痪,这种现象被称为内存泄漏。总体而言,显示进行垃圾回收主要有如下两个缺点:

1.程序忘记及时回收无用内存,从而导致内存泄漏,降低系统性能。

 2.程序错误地回收程序核心类库地内存,从而导致系统崩溃。

与 C/C++程序不同,Java 语言不需要程序员直接控制内存回收,Java 程序的内存分配和回收都是由JRE(JAVA运行时环境)在后台自动进行的。JRE 会负责回收那些不再使用的内存,这种机制被称为垃圾回收(CrarbgrgSolection,GC)。通常 JRE会提供一个后台线程来进行检测和控制。一感都是在CPU空闲或内存不足时自动进行垃圾回收,而程序员无法精确控制垃圾回收的时间和顺序等。

        Java 的推内存是一个运行时数据区,用以保存类的实例(对象),Java虚拟机的堆內存中存储着正在运行的应用程序所建立的所有对象,这些对象不需要程序通过代码来显示地释放。一般来说,堆内存的回收由垃圾回收器来负责,所有的JVM 实现都有一个由垃圾回收器管理的堆內存。垃圾回收是一种动态储存管理技术,它自动形放不再被程序引用地对象,技照特定的垃圾回收算法来实现内存资源的自动回收功能。
         在C/C++中,对象所占用的内存不会被自动释放,如果程序没有显式释放对象所占用的内存,对象所占用的内存就不能分配给其他对象,该内存在程序结束运行之前将一直被占用:而在Java 中,当没有引用变量指向原先分配给某个对象的内存时。该内存便成为垃圾。JVM的一个超级线程会自动释放该内存区。垃圾回收意味着程序不再需要的对象是“垃圾信息”这些信息将被丢弃。
           当一个对象不再被引用时,内存回收它占领的空间,以便空间被后来的新对象使用。事实上,除释放没用的对象外,垃圾回收也可以清除内存记录碎片。由于创建对象和垃圾回收器释放丢弃对象所占的内存空间,内存会出现碎片。碎片是分配给对象的内存块之间的空闲内存区,碎片整理将所占用的堆内存移到堆的一端,JVM将整理出的内存分配给新的对象。
   垃圾回收能自动释放内存空间,减轻编程的负担,这使Java 虚拟机具有两个显著的优点。
        >垃圾回收机制可以很好地提高编程效率。在没有垃圾回收机制时,可能要花许多时间来解決一个难懂的存储器问题。在用Java语言编程时,依靠垃圾回收机制可大大缩短时间。
       >垃圾回收机制保护程序的完整性,垃圾回收是Java 语言安全性策略的一个重要部分。
        垃圾回收的一个潜在缺点是它的开销影响程序性能。Java 虚拟机必须跟踪程序中有用的对象,才可以确定哪些对象是无用的对象,并最终释放这些无用的对象。这个过程需要花费处理器的时间。其次是垃圾回收算法的不完备性,早先采用的某些垃圾回收算法就不能保证100%收集到所有的废弃内存。当然,随着垃坡回收算法的不断改进,以及软硬件运行效率的不断提升,这些问题都可以迎刃而解。
        Java 语言规范没有明确地说明JVM使用哪种垃圾回收算法,但是任何一种垃圾回收算法一般要做两件基本的事情:1.发现无用的对象2.回收被无用对象占用的内存空间,使该空间可被程序再次使用。
       通常,垃圾回收具有如下几个特点。
       >垃圾回收器的工作目标是回收无用对象的内存空间,这些内存空间都是JVM堆内存里的内存空间,垃圾回收器只能回收内存资源,对其他物理资源,如数据库连接,磁盘 I/O 等资源则无能为 。
       >为了更快地让垃圾回收器回收那些不再使用的对象,可以将该对象的引用变量设置为 null,通过这种方式暗示垃圾回收器可以回收该对象。
       >垃圾回收发生的不可预知性。由于不同JVM采用了不同的垃圾回收机制和不同的垃圾回收算法,因此它有可能是定时发生的,有可能是当CPU空闲时发生的,也有可能和原始的垃圾回收一样,等到内存消耗出现极限时发生,这和垃圾回收实现机制的选择及具体的设置都有关系。虽然程序员可以通过调用 Runtime 对象的 gc()或 System.gc()等方法来建议系统进行垃极回收,但这种调用仅仅是建议,依然不能精确控制垃圾回收机制的执行。
       >垃圾回收的精确性主要包括两个方面:一是垃极回收机制能够精确地标记活者的对象;二是垃圾回收器能够精确的定位对象之间的引用关系,前者是完全回收所有废弃对象的前提,否则就能造成内存泄露;而后者则是实现归并和复制等算法的必要条件,通过这种引用关系,可以保证所有对象都能被可靠地回收,所有对象都能够重新分配。从而有效的减少内存碎片的产生。
      >现在的JVM 有多种不同的垃圾回收实现,每种回收机制因其算法差异可能表现各异。有的当垃圾回收开始时就停止应用程序的运行,有的当垃圾回收运行时允许应用程序的线程运行,还有的在同一时间允许垃圾回收多线程运行。

当编写 Java 程序时,一个基本原则是:对于不再需要的对象,不要引用它们。如果保持对这些种象的引用,垃圾回收机制暂时不会回收该对象,则会导致系统可用内存越来越少;当系统可用内存越来越少时,垃圾回收执行的频率就越来越高,从而导致系统的性能下降。
    2011年7月发布的Java 7 提供了G1垃圾回收器来代替原有的并行标记/清除垃圾回收器(简种CMS)。并宣布在未来的日子里,G1垃圾回收器将会逐渐取代原有的CMS垃圾回收器。
    2014年3月发布的 Java 8删除了 HotSpot JVM 中的永生代内存(PermGen,永生代内存主要用于存储一些需要常驻内存、通常不会被回收的信息),而是改为使用本地内存来存储类的元数据信息,并将之称为:元空间(Metaspace),这意味着以后不会再遇到 java.lang.OutOfMemoryEror:PermGen 错误(曾经令许多Java 程序员头痛的错误)。
    2017年9月发布的Java9彻底删除了传统的CMS 垃圾回收器,因此运行JVM的 DefNew + CMS.ParNew + SerialOld、Incremental CMS 等组合全部失效。java 命令(该命令负责启用JVM运行Java 程序)以前支持的以下GC相关选项全部被删除。
  >-Xincgc
  > -XX:+CMSIncrementalMode
  >-XX:+UseCMSCompactAtFullCollection
  > -XX:+CMSFullGCsBeforeCompaction
  > -XX:+UseCMSCollectionPassing
  此外,-XX:+UseParNewGC 选项也被标记为过时,将来也会被删除。
  Java 9默认采用低暂停(low-pause)的Gl垃圾回收器,并为G1垃圾回收器自动确定了几个重要的参数设置,从而保证GI垃圾回收器的可用性、确定性和性能。如果部署项目时为 java 命令指定了
-XX:+UseConcMarkSweepGC选项希望启用 CMS垃圾回收器,系统会显示警告信息。
  Java 11 则再次引入了新的、实验性的z垃圾回收器(简称 ZGC),这个垃圾回收器具有以下几个优点。
  > 垃圾回收时暂停时间不会超过10ms。
   > 暂停时间不会随着堆或实时集合的大小而增加。
  >可处理几百MB到几 TB 的堆内存。
      由于 ZGC的核心是并发垃圾回收器,这意味官可在Java线程继续执行时,完成所有的繁重工作(如标记、压缩、引用处理、表清理等),从而大大降低了该垃圾回收器对程序响应速度的影响。
   由于 ZGC在Java 11 中还处于实验性阶段〈在未米可能取代G1 垃圾回收器),因此 Java 默认并未启用 ZGC 垃圾回收器。如果希望运行 Java 程序时启用 ZGC垃圾回收器,则可在运行 java.命令时使用如下选项。
  > -XX:+UnlockExperimentalVMOptions
  > -XX:+UseZGC
  目前ZGC 垃圾回收器只能在64位的Linux 平台上使用。
  此外,Java 11还引入了实验性的Epsiion 垃圾回收器。严格来说。Epsilon 并不算真正的垃圾回收器,它只负责内存分配,并不负责内存回收。因此,这个垃圾回收器主要在性能测试中比较有用,用于与其他垃圾回收器的开销/收益比进行对比。

Java11改进的垃圾回收器的更多相关文章

  1. JVM 垃圾回收器工作原理及使用实例介绍

    IBM介绍文档:https://www.ibm.com/developerworks/cn/java/j-lo-JVMGarbageCollection/ Java 的新生代串行垃圾回收器中使用了复制 ...

  2. JVM 垃圾回收器工作原理及使用实例介绍(转载自IBM),直接复制粘贴,需要原文戳链接

    原文 https://www.ibm.com/developerworks/cn/java/j-lo-JVMGarbageCollection/ 再插一个关于线程和进程上下文,待判断 http://b ...

  3. C#.Net GC(garbage Collector) 垃圾回收器

    以前一直以为gc的原理很简单,也就是分代处理堆数据,直到我的膝盖中了一箭(好吧 直到有天汪涛和我说他面试携程的面试题 关于服务器和 工作站gc 的区别)其实我当时尚不知道 工作站和服务器有什么区别更不 ...

  4. [译]Java垃圾回收器的类型

    说明:这篇文章来翻译来自于Javapapers 的Types of Java Garbage Collectors 在这部分的教程中我们将讲到可使用的四种不同类型的Java垃圾回收器.垃圾回收是Jav ...

  5. JVM基础系列第9讲:JVM垃圾回收器

    前面文章中,我们介绍了 Java 虚拟机的内存结构,Java 虚拟机的垃圾回收机制,那么这篇文章我们说说具体执行垃圾回收的垃圾回收器. 总的来说,Java 虚拟机的垃圾回收器可以分为四大类别:串行回收 ...

  6. 【转】Java学习---垃圾回收算法与 JVM 垃圾回收器综述

    [原文]https://www.toutiao.com/i6593931841462338062/ 垃圾回收算法与 JVM 垃圾回收器综述 我们常说的垃圾回收算法可以分为两部分:对象的查找算法与真正的 ...

  7. 垃圾回收算法与 JVM 垃圾回收器综述(转)

    垃圾回收算法与 JVM 垃圾回收器综述 我们常说的垃圾回收算法可以分为两部分:对象的查找算法与真正的回收方法.不同回收器的实现细节各有不同,但总的来说基本所有的回收器都会关注如下两个方面:找出所有的存 ...

  8. [Java基础]-- Java GC 垃圾回收器的分类和优缺点

    https://blog.csdn.net/high2011/article/details/80177473?utm_source=blogxgwz2 参考:elasticsearch实战-使用G1 ...

  9. 【转】V8 之旅: 垃圾回收器

    垃圾回收器是一把十足的双刃剑.其好处是可以大幅简化程序的内存管理代码,因为内存管理无需程序员来操作,由此也减少了(但没有根除)长时间运转的程序的内存泄漏.对于某些程序员来说,它甚至能够提升代码的性能. ...

  10. JVM垃圾回收器原理及使用介绍

    JVM垃圾回收器原理及使用介绍 垃圾收集基础 引用计数法(Reference Counting) 标记-清除算法(Mark-Sweep) 复制算法(Copying) 标记-压缩算法(Mark-Comp ...

随机推荐

  1. 【k哥爬虫普法】Python程序员爬取视频资源13万部,一分钱没挣,获刑2年!

    我国目前并未出台专门针对网络爬虫技术的法律规范,但在司法实践中,相关判决已屡见不鲜,K 哥特设了"K哥爬虫普法"专栏,本栏目通过对真实案例的分析,旨在提高广大爬虫工程师的法律意识, ...

  2. 3D圆饼图,可修改颜色,图片等,具体见代码:

    组件代码: <template> <!-- 饼图 --> <div :id="histogramId" v-bind:style="{hei ...

  3. 快递单信息抽取【二】基于ERNIE1.0至ErnieGram + CRF预训练模型

    相关文章: 1.快递单中抽取关键信息[一]----基于BiGRU+CR+预训练的词向量优化 2.快递单信息抽取[二]基于ERNIE1.0至ErnieGram + CRF预训练模型 3.快递单信息抽取[ ...

  4. Pdfium.Net.Free 一个免费的Pdfium的 .net包装器--创建字符子集

    项目地址: Pdfium.Net:https://github.com/1000374/Pdfium.Net PdfiumViewer:https://github.com/1000374/Pdfiu ...

  5. yapi的安装

    1.官方网站:https://hellosean1025.github.io 2.看官方的文档,部署方法: 3. 根据文档 安装环境先: 4. 开始安装yapi 5. 可见需要启动一下 6.重启一下 ...

  6. MySQL 报错:ERROR 2002 (HY000): Can't connect to local MySQL server through socket

    MySQL 报错:ERROR 2002 (HY000): Can't connect to local MySQL server through socket 一.错误现场还原: 下面我们通过三种方式 ...

  7. Vue3学习(16) - 左侧显示分类菜单

    写在前面 和大家不太一样,我觉得今年的自己更加relax,没有亲戚要走,没有朋友相聚,也没有很好的哥们要去叙旧,更没有无知的相亲,甚至可以这么说没有那些闲得慌的邻居. 也可以说是从今天开始,算是可以进 ...

  8. JS Leetcode 264. 丑数 II 题解分析,当暴力无法暴力,让我们弃武从文了解三指针

    壹 ❀ 引 我在JS Leetcode 263. 丑数 题解分析,来认识有趣的丑数吧一文中记录了简单难度的丑数题,那么这篇题解是它的升级版,题目来自LeetCode264. 丑数 II,题目描述如下: ...

  9. 【分布式】load balance 02-consistent hash algorithm 一致性哈希算法原理详解

    负载均衡系列专题 01-负载均衡基础知识 02-一致性 hash 原理 03-一致性哈希算法 java 实现 04-负载均衡算法 java 实现 概念 一致哈希是一种特殊的哈希算法. 在使用一致哈希算 ...

  10. STC89C52驱动MAX7219LED点阵级联, 文字滚动效果

    级联下的传值方式 级联下, N个MAX7219相当于组成了一个8*N bit宽度的锁存器, 如果需要对第M个7219进行写入, 需要做M次寻址+写入后拉高CS, 才能到达这个7219. 如果仅仅对这个 ...