0 JVM知识



:存放局部变量,局部变量表:局部变量;操作数栈:加减乘除的运算;动态链接:去方法区空间,找到代码位置;方法出口:返回main方法的位置继续执行。

:存放对象

程序计数器:为了防止更高优先权的线程抢夺CPU后,记得程序切回来从哪里开始执行。 程序计数器的值是,代码指令的地址值。 由字节码执行引擎来修改。
方法区【元空间】:常量+静态变量+类信息【不常改变的信息】

一、说一说JVM的内存模型。


二、JAVA类加载的全过程是怎样的?什么是 双亲委派机制?有什么作用?

JAVA的类加载器: AppClassloader -> ExtClassloader -> BootStrap
Classloader
每种类加载器都有他自己的加载目录。
JAVA中的类加载器: AppClassLoader , ExtClassLoader -> URLClassLoader ->SecureClassLoader -> ClassLoader
每个类加载器对他加载过的类,都是有一个缓存的。

双亲委派:向上委托查找,向下委托加载。 作用:保护JAVA的层的类不会被应用
程序覆盖。
类加载过程: 加载 -》 连接 -》 初始化
加载:把Java的字节码数据加载到JVM内存当中,并映射成JVM认可的数据结构。
连接:分为三个小的阶段:
1、验证:检查加载到的字节信息是否符合JVM规范。
2、准备: 创建类或接口的静态变量,并赋初始值 半初始化状态
3、解析:把符号引用转为直接引用
初始化
一个对象从加载到JVM,再到被GC清除,都经历了什么过程?
method{ ClassLoaderDemo1 c =new ClassLoaderDemo1(); c.xxx} GC
1、用户创建一个对象,JVM首先需要到方法区去找对象的类型信息。然后再创建对
象。
2、JVM要实例化一个对象,首先要在堆当中先创建一个对象。-> 半初始化状态
3、对象首先会分配在堆内存中新生代的Eden。然后经过一次Minor GC,对象如果
存活,就会进入S区。在后续的每次GC中,如果对象一直存活,就会在S区来回拷
贝,每移动一次,年龄加1。-> 多大年龄才会移入老年代? 年龄最大15, 超过一
定年龄后,对象转入老年代

4、当方法执行结束后,栈中的指针会先移除掉
5、堆中的对象,经过Full GC,就会被标记为垃圾,然后被GC线程清理掉

三、怎么确定一个对象到底是不是垃圾? 什么 是GC Root?

有两种定位垃圾的方式:
1、引用计数: 这种方式是给堆内存当中的每个对象记录一个引用个数。引用个数
为0的就认为是垃圾。这是早期JDK中使用的方式。引用计数无法解决循环引用的问
题。
2、根可达算法: 这种方式是在内存中,从引用根对象向下一直找引用,找不到的
对象就是垃圾。
哪些是GC Root? Stack -> JVM Stack, Native Stack, class类, run-time
constant pool 常量池, static reference 静态变量。

四、JVM有哪些垃圾回收算法?

1.MarkSweep 标记清除算法
这个算法分为两个阶段,
标记阶段:把垃圾内存标记出来,
清除阶段:直接将垃圾
内存回收。

这种算法是比较简单的,但是有个很严重的问题,就是会产生大量的内存碎片
2.Copying 拷贝算法
为了解决标记清除算法的内存碎片问题,就产生了拷贝算法。拷贝算法将内存分为
大小相等的两半,每次只使用其中一半。垃圾回收时,将当前这一块的存活对象全
部拷贝到另一半,然后当前这一半内存就可以直接清除。

这种算法没有内存碎片,但是他的问题就在于浪费空间。而且,他的效率跟存货对象的个数有关
3.MarkCompack 标记压缩算法
为了解决拷贝算法的缺陷,就提出了标记压缩算法
这种算法在标记阶段跟标记清除算法是一样的,但是在完成标记之后,不是直接清理垃圾内存,而是将存活对象往一端移动,然后将端边界以外的所有内存直接清除。

这三种算法各有利弊,各自有各自的适合场景。

五、JVM有哪些垃圾回收器?他们都是怎么工 作的?什么是STW?他都发生在哪些阶段?什 么是三色标记?如何解决错标记和漏标记的问 题?为什么要设计这么多的垃圾回收器?

4.STW: Stop-The-World。
是在垃圾回收算法执行过程当中,需要将JVM内存冻结的一种状态。在STW状态下,JAVA的所有线程都是停止执行的-GC线程除外,native方法可以执行,但是,不能与JVM交互。GC各种算法优化的重点,就是减少STW,同时这也是JVM调优的重点。

JVM的垃圾回收器:
1.Serial 串行
整体过程比较简单,就像踢足球一样,需要GC时,直接暂停,GC完了再继续。
这个垃圾回收器,是早期垃圾回收器,只有一个线程执行GC。在多CPU架构下,性
能就会下降严重。只适用于几十兆的内存空间。

2.Parallel 并行
在串行基础上,增加多线程GC。PS+PO这种组合是JDK1.8默认的垃圾回收器。在
多CPU的架构下,性能会比Serial高很多。

CMS Concurrent Mark Sweep
核心思想,就是将STW打散,让一部分GC线程与用户线程并发执行。 整个GC过程
分为四个阶段
1、初始标记阶段:STW 只标记出根对象直接引用的对象。
2、并发标记:继续标记其他对象,与应用程序是并发执行。
3、重新标记: STW 对并发执行阶段的对象进行重新标记。
4、并发清除:并行。将产生的垃圾清除。清除过程中,应用程序又会不断的产生新
的垃圾,叫做浮动垃圾。这些垃圾就要留到下一次GC过程中清除。

G1 Garbage First 垃圾优先
他的内存模型是实际不分代,但是逻辑上是分代的。在内存模型中,对于堆内存就
不再分老年代和新生代,而是划分成一个一个的小内存块,叫做Region。每个
Region可以隶属于不同的年代
GC分为四个阶段:
**第一:**初始标记 标记出GCRoot直接引用的对象。STW
**第二:**标记Region,通过RSet标记出上一个阶段标记的Region引用到的Old区
Region。
**第三:**并发标记阶段:跟CMS的步骤是差不多的。只是遍历的范围不再是整个Old
区,而只需要遍历第二步标记出来的Region。
**第四:**重新标记: 跟CMS中的重新标记过程是差不多的。
**第五:**垃圾清理:与CMS不同的是,G1可以采用拷贝算法,直接将整个Region中
的对象拷贝到另一个Region。而这个阶段,G1只选择垃圾较多的Region来清理,
并不是完全清理。

CMS的核心算法就是三色标记
三色标记:是一种逻辑上的抽象。将每个内存对象分成三种颜色: 黑色:表示自己和成员变量都已经标记完毕。 灰色:自己标记完了,但是成员变量还没有完全标记
完。白色:自己未标记完。
CMS通过增量标记 increment update 的方式来解决漏标的问题。

六、如何进行JVM调优?JVM参数有哪些?怎 么查看一个JAVA进程的JVM参数?谈谈你了 解的JVM参数。如果一个java程序每次运行一 段时间后,就变得非常卡顿,你准备如何对他 进行优化?

JVM调优主要就是通过定制JVM运行参数来提高JAVA应用程度的运行数据
JVM参数大致可以分为三类:
1、 标注指令: -开头,这些是所有的HotSpot都支持的参数。可以用java -help 打
印出来。
2、非标准指令: -X开头,这些指令通常是跟特定的HotSpot版本对应的。可以用
java -X 打印出来。
3、不稳定参数: -XX 开头,这一类参数是跟特定HotSpot版本对应的,并且变化
非常大。详细的文档资料非常少。在JDK1.8版本下,有几个常用的不稳定指令:
java -XX:+PrintCommandLineFlags : 查看当前命令的不稳定指令。
java -XX:+PrintFlagsInitial : 查看所有不稳定指令的默认值。
java -XX:+PrintFlagsFinal: 查看所有不稳定指令最终生效

七、JVM调优的目的?

为了减少GC。MINOR GC FULL GC

3.图灵学院-----阿里/京东/滴滴/美团整理----高频JVM调优篇相关推荐

  1. 10.图灵学院-----阿里/京东/滴滴/美团整理----安全验证篇

    一.什么是认证和授权?如何设计一个权限认 证框架? 认证: 就是对系统访问者的身份进行确认. 用户名密码登录. 二维码登录.手机短信登录.指纹.刷脸... 授权:就是对系统访问者的行为进行控制.授权通 ...

  2. 阿里京东滴滴等大厂面试题汇总

    文章目录 11月面:京东一面[京东云与AI-协同办公]: 京东一面现场面[京东云与AI-平台创新组]: 京东二面: 11月面:滴滴视频面[橙心优选]: 11月面:国美零售[大数据-搜索组] 8月面:阿 ...

  3. JVM调优,面到了阿里性能优化师!

    小K 菜哥,我看你朋友圈,你好像换工作了? 菜哥 对啊,前阵子被产品经理烦的头疼,就想换工作了.刚好找到一个不错的. 小K 给我说说呗,让我也参考一下,我现在工资才15K,主管死坑,我也想换工作了 菜 ...

  4. JVM调优学习笔记整理

    1.相关基础知识 1.1 JVM内存模型 参见blog:https://blog.csdn.net/lydon1314/article/details/120716778 网址:https://zhu ...

  5. 美团面试:熟悉哪些JVM调优参数,幸好我准备过!

    关注公众号"Java后端技术全栈" 回复"000"获取程序员必备电子书 大家好,我是田维常,江湖人称老田.田哥.田神,今天来和大家分享JVM调优参数. 之前,我 ...

  6. BAT/头条/小米/京东/滴滴/美团...互联网大厂员工一年究竟能挣多少钱?

    点击"技术领导力"关注∆  每天早上8:30推送 本文转自:HR人力资源成长俱乐部 声明:本文数据部分来自所涉公司官方微信公众号(如:字节范儿),部分来自脉脉各公司职言区,另有部分 ...

  7. 参数调优为什么要采样_3年Java外包,内推阿里过关斩将,最后却倒在调优经验上! - Java架构师追风...

    前言 在当下的时代,懂高并发性能调优,一定是你在技术进阶赛道变得牛逼的加分项.不论,你是开发,架构还是管理岗,亦或者是其他互联网相关岗位. 因为毫不夸张的说,在现在动辄过千万级的并发流量环境下,懂得并 ...

  8. 把最新JAVA面试真题(阿里/京东/菜鸟)整理出来,却被自己菜哭了

    前言 2020终于迎来了最后的两个月,这一年,全世界都不安定,被疫情包围,渐渐治愈和免疫,国内虽然看着和往常没有多大的区别,但对于经济的冲击,不知道又倒退了多少年?大大小小的公司面临倒闭或已破产,对于 ...

  9. 阿里云服务器|centos查看并发数调优

    背景 博主这几天发现服务器负载蹭蹭上涨,特此记录一篇: 借鉴这篇文章:主要原因 阿里云服务器配置:2H4G centos7 docker基础配置包含:taos_img.mysql.nginx.naco ...

  10. 阿里出品的这份Java性能调优实战手册,直接涨薪25K,真的香啊

    现在,网站和应用程序的功能越来越丰富了,对网络和设备性能的要求自然也越来越高.因此,实现高水平的系统性能,逐渐成为每一位程序员不可或缺的底层能力.可是,传统的性能优化视角,更多的是从问题与测量数据的角 ...

最新文章

  1. asp.net动态换肤
  2. python处理excel文件-python处理Excel文件
  3. [bzoj2893] 集合计数
  4. python 输出字符串编码_Python print 字符串编码问题
  5. 密码技术--国密SM3哈希算法及Go语言应用
  6. 第三次学JAVA再学不好就吃翔(part101)--IO流
  7. 责任链模式在Android中的应用
  8. Linux vsyscall和vDSO加速系统调用
  9. php里 \r\n换行问题
  10. 【笔记】关于OpenCV中的去畸变代码
  11. 用Linux编写C语言程序
  12. sspanel 常用审计规则
  13. Linux平台(Ubuntu或者树莓派)上下载磁力链接;使用Deluge下载
  14. 泛函分析复习笔记(二)线性算子与线性泛函
  15. 上海杉达学院计算机课程,上海杉达学院计算机科学与技术专业介绍
  16. 解决虚拟专用网络拨号后本地上网流量都走此网络的问题
  17. 从Linux角度以及JVM源码,深入NIO的细节
  18. 跳高女神oracle,她是跳高新星,颜值与实力并存,现被称为“最美跳高女神”!...
  19. css字行高怎么设,css文本行高怎么设置-电脑自学网
  20. 视频号直播刚改版后怎么开通企业微信

热门文章

  1. 内网服务器设置proxy权限联通外网
  2. vga接口和hdmi接口的区别
  3. AppleStore 原始ipa文件提取
  4. 餐厅点菜c语言程序代码,餐馆点菜系统C语言源代码.pdf
  5. PPT超链接字体颜色修改方法
  6. Amazon 亚马逊 AWS S3 跨源资源共享 (CORS)设置
  7. psf2otf函数的解释
  8. abbyyfinereader软件下载中文注册免安装激活版
  9. 挂载NFS的两种方法
  10. 超级表格第21行的秘密