此次JVM知识点包含以下几个部分

1.类加载机制

2.jvm运行时数据区

3.java对象内存布局

4.jvm内存模型

5.垃圾回收机制

6.垃圾收集器

7.问题排查

一 类加载机制

主要说的部分是这一块

那么如何装载呢,这就谈到了咱们的双亲委派机制,简单来说就是类,向上递交,向下加载,源码和图如下

if (parent != null) {
c = parent.loadClass(name, false);
} else {
//由于BootstrapClassLoader是C++写的,在java中被视为null
c = findBootstrapClassOrNull(name);
}

  

那么装载的过程是什么呢,如图

装载干了啥呢,大白话说就是一个你把一个java文件转换成二进制给jvm处理,官方一点的语言就是:

    ①通过一个类的全限定名获取这个类的二进制字节流。

    ②将这个字节流的静态存储结构转换为方法区的运行时数据结构。

    ③在堆中生成一个这个二进制字节流的Class对象作为访问入口。

那么链接呢,验证:字面意思,准备:赋默认值,解析:符号引用转换为直接引用

二 运行时数据区

话不多说,看法宝,上图

方法区

存放:静态变量,常量,即时编译的class文件,类信息。
区别:1.8之前叫Perm Space 永久代,现在叫Meta Space 元空间

虚拟机栈

存放:栈帧;即方法的调用,-Xss可以设置栈大小,默认1M;使栈溢出的使递归。

构成:局部变量表;方法中定义的变量与方法的参数,

操作数栈;压栈出栈存放数据的地方,

动态链接;这个的作用就是知道谁调用的,比方说java中的多态,最后会知道具体是哪个类,
方法返回地址;字面意思

存放:对象及数组

接下来咱们看一下这个指针指向问题

栈指向堆; 栈帧(方法中有一个变量)即 Object obj = new Object();
方法区指向堆;静态变量,private static Object obj = new Object();
堆指向方法区;由于方法区中存放的类信息,所以对于多态如何识别,这一点,就说明堆中有指向方法区的指针。

三 java对象内存布局

四 jvm内存模型

内存模型可以认为是运行时数据区的落地,那么当一个对象来的时候,如何分配内存空间呢

首先放入Eden区,看够不够,不够,minorGC,再试试Survivor是否足够,如果不够;
放入老年代看看够不够,不够就来一次Full GC(minorGC+MajorGC);
如果还不够就OOM了。
那么对象进入老年代的条件是什么呢

新生代中年龄大于15;
大对象(-XX:PretenureSizeThreshold 配置这个,大于这个数的就成为大对象)
动态年龄:即survivor区中 同一年龄的超过了该区一半,那么大于等于该年龄的对象直接进入老年代
minorGC,新生代放不下的时候
那么这里边放了这么对象,该如何回收呢

五 垃圾回收机制

什么是垃圾,如何确定垃圾呢

引用计数法

没有任何指针指向的就是垃圾,但是无法解决循环引用的问题

可达性分析

由GCRoot(静态成员,Thread线程,虚拟机栈的变量表,本地方法栈中的变量,类加载器,常量)作为头,向下顺藤摸瓜,能摸得到的就是好瓜,摸不到的就回收扔了。

既然已经确定了垃圾,那么如何回收呢

四种垃圾回收算法

标记-清除:将标记的清除掉,弊端就是内存不连续,容易产生内存碎片;
复制:内存分两块,将一端复制到另一端,解决了内存不连续,弊端就是内存有效区只由一半;
标记-整理:将垃圾回收后压缩整理一下,解决了内存有效区只有一半的问题;
分代算法:个人认为这个属于一种思想,即对前三种的一种总结;老年代用标记清除,标记整理,新生代用复制
算法说完了,那么算法的落地,如何实现的呢,这就要说到垃圾收集器了

六.垃圾收集器

可以看到从刚开始的Serial到现在的G1乃至ZGC的最多10ms停顿可以看到java一直在寻找最短的停顿时间,这个也是一直优化的方向。

并行收集:多个线程一起收集

并发收集:跟用户线程一起跑

CMS和G1的区别有哪些呢?

CMS,四个步骤为,初始标记-并发标记-重新标记-并发清理

G1,四个步骤,初始标记-并发标记-最终标记-筛选回收(对各个Region的回收价值进行排序根据用户期望的GC停顿时间制定回收计划)

G1可以设置停顿时间(-XX:MaxGCPauseMillis=20),就是因为他的Region,可以理解为一面墙分成了多个砖头,一些砖头的集合称为老年代,一些称为新生代。

这些都知道了,那么出现错误该如何排查呢

七 问题排查

1.频繁FullGC

导致频繁FullGC的原因有

System.gc()
jmap -dump:format=b,fifile=heap.hprof PID

老年代内存不够
步骤

打印FullGC前后的日志 -XX:+HeapDumpBeforFullGC -XX:+HeapDumpAfterFullGC -XX:+HeapDumpPath=a.prof
使用MAT工具进行分析,可以看堆中占用情况,以及class的新建情况。
2.线上CPU负载过高排查

采用TOP命令,查出占用cpu最高的java应用
top -Hp PID查询出占用cpu最高的线程
找出该线程ID,转换成16进制 printf "%x\n" tid
jstack PID > d.txt
打开d.txt,查询该16进制的tid就能找到了
3.吞吐量调优

使用命令打印出gc.log -XX:+PrintGCDetails -Xloggc:gc.log
使用gcviewer来分析日志
根据具体情况调整堆栈大小,停顿时间等参数,再看gcviewer分析出来的数据如何。
4.死锁排查

使用 java bin目录下自带的visualVM工具,可远程链接可本地链接
连接之后,点击线程一栏,便会出现红字 发现死锁
点击旁边的Dump按钮即可进入dump文件中,往下翻即可看到提示的哪一行出现了死锁,然后定位到代码

新鲜出炉!花了三天整理的JVM复习知识点,面试突击必备!的更多相关文章

  1. 新鲜出炉!2020年最新java面试题大全,面试突击必备!

    前言 发现网上很多Java面试题都没有答案,所以花了很长时间搜集整理出来了一套Java面试题,希望对大家有帮助哈~ 打算这几天每天更新15~20题.(这样有助于你们阅读和理解!)我们先从简单的开始 1 ...

  2. 新鲜出炉的30个精美的 jQuery & CSS3 效果【附演示和教程】

    新鲜出炉的30个精美的 jQuery & CSS3 效果[附演示和教程]   作为最流行的 JavaScript 开发框架,jQuery 在现在的 Web 开发项目中扮演着重要角色,它简化了 ...

  3. 微信小程序开发视频教程新鲜出炉

    微信小程序开发公测了,可是对于新手来说,不同的框架不同的开发机制,如何快速适应呢?微信小程序开发视频教程新鲜出炉了,从零开始一步一步搭建微信小程序,每个章节都会涉及到不同的知识点,等教程学习完你不但掌 ...

  4. 刚写完的商城erp + 这个商城前台,新鲜出炉。自己1个人写, 包括php框架和前端html页面.

    刚写完的商城erp + 这个商城前台,新鲜出炉.自己1个人写, 包括php框架和前端html页面. 刚写完的商城erp + 这个商城前台,新鲜出炉.自己1个人写, 包括php框架和前端html页面.

  5. 23套新鲜出炉的网站和手机界面 PSD 素材

    Web 用户界面,移动用户界面和线框套件对设计师很有用,因为这些套件让他们使用快速和有效的方式复制用户界面.这些类型的工具包提供了一个基本的用户界面元素,用于它们需要制作的网站或软件模型. 在这篇文章 ...

  6. 22套新鲜出炉的 Web & Mobile PSD 用户界面素材

    在这篇文章中,我们展示的是自由和清新的 UI 设计素材套件.这些线框图和 UI 设计工具包让设计师在设计用户界面原型的时候能够非常便利. Web 用户界面,移动用户界面和线框套件对设计师很有用,因为这 ...

  7. 20个新鲜出炉的网站模板【HTML & PSD】

    这里给大家分享20 个新鲜出炉的免费网站模板.这些设计元素将成为你下一个项目的重要素材,可以帮你节省很多的时间.与往常一样,我们经常漫游网络,寻找最好的资源, HTML.CSS 和 PSD 等等,记得 ...

  8. 分享25个新鲜出炉的 Photoshop 高级教程

    网络上众多优秀的 Photoshop 实例教程是提高 Photoshop 技能的最佳学习途径.今天,我向大家分享25个新鲜出炉的 Photoshop 高级教程,提高你的设计技巧,制作时尚的图片效果.这 ...

  9. PS教程:20个新鲜出炉的 Photoshop 中级教程

    Photoshop 实例教程是提高 Photoshop 技能的最佳学习途径.今天,我向大家分享最新20个 Photoshop 进阶教程,提高你的图片处理技巧,制作时尚的效果.这些教程可以帮助把你的想法 ...

随机推荐

  1. APP打开(一)—以亲身经历谈APP注册登录

    如果不是自己接手过这样的产品,我可能也很难相信,会有公司能够做出十四个注册页面的APP,将选站点.输账号.输密码.用户协议.用户权限等全部拆解成一个一个单独的页面来做,用户在注册的时候仿佛在攀登一座云 ...

  2. Spark RDD详解 | RDD特性、lineage、缓存、checkpoint、依赖关系

    RDD(Resilient Distributed Datasets)弹性的分布式数据集,又称Spark core,它代表一个只读的.不可变.可分区,里面的元素可分布式并行计算的数据集. RDD是一个 ...

  3. 闭包 - Js函数笔记

    闭包 当函数被保存到外部时,将会生成闭包 闭包会导致原有作用域链不释放,造成内存泄漏 类似的代码就叫闭包 闭包的运行作用域 代码 a被执行,b被定义并保存出来 a结束,b被执行时,a的执行期上下文指向 ...

  4. Lombda表达式(五)

    public class Test05 { /* * lambda表达式是用来简化匿名内部类的一种函数式编程的语法. * 只有SAM接口才能使用lambda表达式 * 方法引用和构造器引用是用来简化l ...

  5. lua table面向对象扩展

    一 .table扩展 -- 返回table大小 table.size = function(t) local count = 0 for _ in pairs(t) do count = count ...

  6. 《JavaScript高级程序设计》——第四章 变量、作用域和内存管理

    JavaScript变量可以用保存两种类型的值:基本类型值和引用类型值.基本类型的值源自以下基本类型数据:Undefined.Null.Boolean.Number和String. 从一个变量向另一个 ...

  7. nb-iot技术实现跟踪功能的应用

    在互联网和连接的世界里,nb-iot风靡一时.企业和个人正在利用nb-iot技术和nb-iot设备的可靠,快速连接能力,对其技术系统进行渐进式更改,并创建一个互联的"智能"世界. ...

  8. mq_open失败,Invalid argument

    经四处查找,终于发现原因: (1)attr.mq_maxmsg 不能超过文件 /proc/sys/fs/mqueue/msg_max 中的数值,我的机器上面是10. (2)attr.mq_msgsiz ...

  9. Linux 系统编程 学习:06-基于socket的网络编程1:有关概念

    Linux 系统编程 学习:006-基于socket的网络编程1:有关概念 背景 上一讲 进程间通信:System V IPC(2)中,我们介绍了System IPC中关于信号量的概念,以及如何使用. ...

  10. 致萌新与不会用 NOI Linux 的 OIer

    全文绝大部分转载自:这篇好文章啊. 目录 1:GUIDE 2:Gedit 原文 打开 编译运行 3.Vim 3-1:这东西咋开啊 3-2:这东西咋用啊 4.编译与运行 5.调试 6.CSP竞赛中编写代 ...