〇、前言

简历写上:熟悉GC常用算法,熟悉常见垃圾回收器、具有实际JVM调优实战经验

瞬间涨3k

一、什么是garbage

Java中垃圾回收器自动进行垃圾回收,不用自己回收

new 对象在内存中,c++/c手动删除,而java无需要写代码

判断什么是垃圾:

方法1:有无引用指向--reference count,是有问题的,无法解决循环引用(引用计数在Python中有使用)

方法2:从根上能找到的对象,即从main函数能找到的对象--根可达算法

二、GC算法-找到垃圾如何清除(提出五十多年未变过)

1、标记清除算法Mark-Sweep

缺陷:碎片化现象很严重

2、拷贝算法Copying

无论空间多大,全部空间一分为二

在某一个空间内调用程序,当程序调用结束,选择有用的对象,放到另一半

并将当前部分的那些没有用的对象,全部回收

优势:效率高,一次性清除很大的空间

缺陷:浪费空间,有一半用不了

3、标记整理Mark-Compact

标记的同时,把有用的对象排到前面

一边找,一遍标记,一边整理

三、垃圾回收器Garbage Collector

1、概述图示

用虚线连接,表示两个垃圾回收器有联系,可以配合使用

往往是上下配对

2、最古老的垃圾回收器:Serial-连续的,序列的,单线程的

Serial:单线程,Stop-the-world,简称STW,进行垃圾回收的时候,业务线程全部停止

垃圾回收开始干活,java程序变卡

对网站的影响:对用户的反馈不友好,容易出现卡顿现象

调优:STW的时间要短,让用户迅速得到反馈

3、内存变大时,可以多加几个线程-Parallel Scavenge(并行)

线程数量可以增多,但不能无限增多

当内存很多时,进行STW,仍然会浪费很多时间,多线程卡顿时间也会变长

实际1.8生产环境默认:PS+PO

Oracle jdk11收费,Open Jdk免费

调优:可以使用G1(jdk1.9后的默认)

4、Concurrent Mark Sweep,CMS-并发

(1)什么是并发:当垃圾回收线程和正在工作的线程同时开始工作时,叫做并发

一边丢线团,一边清理线程

小线团就是new出来的多个对象

从CMS之后都是并发

(2)存在的问题1

小线团之间会存在关联,过程很乱

业务线程不断运行,将其标记为不是垃圾,但下一秒就变成垃圾了,不再有引用

而垃圾回收线程从根上寻找时,两个线程在不同的CPU上运行,但垃圾回收却将其标记为有用,不会将其作为垃圾进行回收

会产生浮动垃圾:垃圾在这次回收中没有被清理掉,只能在下次回收

(3)存在的问题2

回收时标记为垃圾

但工作线程将其与现有对象建立连接

被回收后,再去访问,得到的是空值

(4)怎么建立连接-找到没有引用的对象

是算法带来的问题

标记过程分为多个阶段,标记完后会继续--三色标记算法

【JVM调优】Day01:Garbage的概念、垃圾回收的算法(标记清除、拷贝、标记压缩)、各种垃圾回收器(Serial、Parallel、CMS并发)及存在的问题的更多相关文章

  1. [转]JVM调优总结:一些概念

    JVM调优总结:一些概念 原文出处: pengjiaheng 数据类型 Java虚拟机中,数据类型可以分为两类:基本类型和引用类型.基本类型的变量保存原始值,即:他代表的值就是数值本身:而引用类型的变 ...

  2. JVM调优总结:一些概念

    数据类型 Java虚拟机中,数据类型可以分为两类:基本类型和引用类型.基本类型的变量保存原始值,即:他代表的值就是数值本身:而引用类型的变量保存引用值.“引用值”代表了某个对象的引用,而不是对象本身, ...

  3. jvm 调优(1)概念

    数据类型 Java虚拟机中,数据类型可以分为两类:基本类型和引用类型.基本类型的变量保存原始值,即:他代表的值就是数值本身:而引用类型的变量保存引用值.“引用值”代表了某个对象的引用,而不是对象本身, ...

  4. JVM调优基础到进阶

    GC和GC Tuning GC的基础知识 1.什么是垃圾 C语言申请内存:malloc free C++: new delete c/C++ 手动回收内存 Java: new ? 自动内存回收,编程上 ...

  5. JVM调优的几种策略

    一.JVM内存模型及垃圾收集算法  1.根据Java虚拟机规范,JVM将内存划分为: New(年轻代) Tenured(年老代) 永久代(Perm) 其中New和Tenured属于堆内存,堆内存会从J ...

  6. JVM调优方法

    目 录 目 录 I 诠释JVM调优 1 第1章 JVM内存模型及垃圾收集算法 1 1.1 根据Java虚拟机规范,JVM将内存划分为 1 1.2 垃圾回收算法 1 第2章 内存泄漏及解决方法 2 2. ...

  7. JVM调优总结(九)-新一代的垃圾回收算法

    垃圾回收的瓶颈 传统分代垃圾回收方式,已经在一定程度上把垃圾回收给应用带来的负担降到了最小,把应用的吞吐量推到了一个极限.但是他无法解决的一个问题,就是Full GC所带来的应用暂停.在一些对实时性要 ...

  8. java虚拟机学习-JVM调优总结-新一代的垃圾回收算法(11)

    垃圾回收的瓶颈 传统分代垃圾回收方式,已经在一定程度上把垃圾回收给应用带来的负担降到了最小,把应用的吞吐量推到了一个极限.但是他无法解决的一个问题,就是Full GC所带来的应用暂停.在一些对实时性要 ...

  9. java虚拟机学习-JVM调优总结-分代垃圾回收详述(9)

    为什么要分代 分代的垃圾回收策略,是基于这样一个事实:不同的对象的生命周期是不一样的.因此,不同生命周期的对象可以采取不同的收集方式,以便提高回收效率. 在Java程序运行的过程中,会产生大量的对象, ...

  10. JVM调优总结(4):分代垃圾回收

    为什么要分代 分代的垃圾回收策略,是基于这样一个事实:不同的对象的生命周期是不一样的.因此,不同生命周期的对象可以采取不同的收集方式,以便提高回收效率. 在Java程序运行的过程中,会产生大量的对象, ...

随机推荐

  1. Docker与Containerd使用区别

    文章转载自:https://cloud.tencent.com/developer/article/1984040 Kubernetes 在 1.24 版本里弃用并移除 docker shim,这导致 ...

  2. Logstash:Email output plugin 检查日志中是否还有某些错误信息并发送邮件报警

  3. 使用metricbeat监控system和nginx

    下载并解压缩metricbeat metricbeat.yml配置文件设置: setup.kibana: host: "192.168.75.21:5601" output.ela ...

  4. POJ3280 Cheapest Palindrome (区间DP)

    dp[i][j]表示将字符串子区间[i,j]转化为回文字符串的最小成本. 1 #include<cstdio> 2 #include<algorithm> 3 #include ...

  5. 会话跟踪技术 - Cookie 和 Session 快速上手 + 登陆注册案例

    目录 1. 会话跟踪技术概述 2. Cookie 2.1 Cookie的概念和工作流程 2.2 Cookie的基本使用 2.3 Cookie的原理分析 2.4 Cookie的使用细节 2.4.1 Co ...

  6. uni-app 如何优雅的使用权限认证并对本地文件上下起手

    这里给大家分享我在网上总结出来的一些知识,希望对大家有所帮助 1.起因 最近有一个需求,需要使用自定义插件,来对接硬件功能,需要配合对手机的权限进行判断和提示,并在对接后对本地文件进行操作,这里给大家 ...

  7. iptables基本使用举例

    一.链的基本操作 1.清除所有的规则. 1)清除预设表filter中所有规则链中的规则. # iptables -F 2)清除预设表filter中使用者自定链中的规则. #iptables -X #i ...

  8. [Thread] 多线程顺序执行

    Join 主线程join 启动线程t1,随后调用join,main线程需要等t1线程执行完毕后继续执行. public class MainJoin { static class MyThread i ...

  9. 后端框架学习-----mybatis(使用mybatis框架遇到的问题)

    1.配置文件没有注册(解决:在核心配置文件中注册mapper,注册有三种形式.资源路径用斜杆,包和类用点) <mappers> <!--每一个mapper.xml文件都需要在myba ...

  10. 第一种方式:使用form表单将前端数据提交到servelt(将前端数据提交到servlet)

    第二种使用Ajax的形式将前台的数据传输到后台:https://blog.csdn.net/weixin_43304253/article/details/120335657 1.form表单 引入了 ...