java面试(jvm)

JVM内存模型

细分Eden:

java类加载过程?双亲委派机制?一个对象从加载到JVM,再到被GC清除过程?

JAVA类加载器:AppClassLoader - ExtClassLoader - BootStrapClassLoader。每种类加载器都有他自己的加载目录。

每个类加载器对他加载过的类都有一个缓存

双亲委派:向上委托查找,向下委托加载。为了保护java底层的类不会被应用程序覆盖。

类加载过程:加载 - 连接 - 初始化

加载:通过双亲委派机制把java的字节码数据加载到JVM内存中,并映射成JVM认可的数据结构。

连接:分为3个阶段:1.验证:检查加载到字节信息是否符合JVM规范。2.准备:创建类或接口的静态变量,并赋初始值,半初始化状态。3.解析:把符号引用转化为直接引用

一个对象从加载到JVM,再到被GC清除经历了什么过程?

method{ClassLoaderDemo c = new ClassLoaderDemo; c.xxx} GC

1.用户创建一个对象,JVM先需要在方法区去找对象的类型信息,然后再创建对象。

2.JVM要实例化对象,首先再堆中创建一个对象。-半初始化状态

3.对象先分配在堆内存中新生代的Eden区。然后经过一次Minor GC后对象如果存活会进到S区,后续每次GC对象如果一直存活,就会再S区来回拷贝并给年龄+1(年龄最大15),多次GC后会放入老年代。

4.当方法执行结束后,栈中的指针会先移除掉。

5.堆中的对象,经过Full GC,就会标记为垃圾,然后被GC线程清理掉。

怎么确定一个对象是不是垃圾,什么是GC Root?

有两种垃圾回收机制:

1.引用计数:这种方式是给堆内存当中的每个对象记录一个引用计数,引用个数为0的就认为是垃圾。问题是无法解决循环引用的问题,会造成内存泄漏。

2.根可达算法:内存中从引用根对象向下一直找引用,找不到的对象就是垃圾,可解决循环引用。

GC Root:Stack(JVM Stack,Native Stack),class类,run-time constant pool常量池,static reference静态变量。

JVM有哪些垃圾回收算法?

https://www.cnblogs.com/hellostar/p/16497856.html

1.MarkSweep标记清除算法

这个算法分为两个阶段:标记阶段:从引用根节点开始所有被引用的对象,垃圾内存标记出来。清除阶段:直接将垃圾内存回收。

缺点:GC时要停掉整个应用,清除后的空闲内存不连续,产生内存碎片。

2.Copying拷贝算法

将内存分为两半,每次只使用一半,垃圾回收时麻将存活对象拷贝至另一半,这一半全部清除。

缺点:需要两倍内存空间。

3.MarkCompack标记压缩算法

结合了标记-清除和复制优点,第一阶段从根节点标记被引用对象,第二阶段遍历整个堆,把清除未标记对象并且把存活对象压缩到其中一块,按顺序排放。

缺点:算法复杂度高

JVM有哪些垃圾回收器?什么是STW?他们发生在哪些阶段?什么是三色标记?如何解决错标记和漏标记?为什么要设计这么多垃圾回收器? -> 内存逐渐变大

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

JVM垃圾回收器:

1.Serial串行:

需要GC时,直接暂停,GC完继续执行。早期垃圾回收期。只有一个线程执行GC,多CPU下性能会下降,适用于几十兆内存的空间。

2.Parallel并行:

多线程GC,PS+PO组合是JDK8默认的垃圾回收器,多核CPU下,性能高。

CMS:Concurrent Mark Sweep。将STW打散,让一部分GC线程并发执行。

1.初始标记阶段:STW只标记出根对象直接引用的对象。

2.并发标记:继续标记其他对象,与应用程序时并发执行。

3.重新标记:STW对并发执行阶段的对象进行重新标记。

4.并发清除:并行,将产生的垃圾清除,清除过程中,会不断产生新的垃圾,这些垃圾会留在下次GC。

G1:Garbage Fitst垃圾优先。这种内存模型中对于堆内存不分老年代和新生代,而是划分成小内存块Region。

1.初始标记,标记出GCRoot直接引用的对象。STW

2.标记Region,通过RSet标记出上一个阶段标记的Region引用到Old区的Region

3.并发标记阶段,跟CMS差不多,只是遍历范围不再是整个old区,而是只需要遍历第二部标记出来的Region。

4.重新标记,跟CMS中的重新标记过程是差不多的。

5.垃圾清理:与CMS不同的是,G1可以采用拷贝算法,直接将整个Region中的对象拷贝到另一个Region,而这个阶段,G1只选择垃圾较多的Region来清理,并不是完全清理。

CMS的核心算法就是三色标记。

三色标记:将内存分为三种颜色:黑色(自己和成员变量都标记完毕),灰色(自己标记完,成员变量内没有),白色(自己未标记完)

漏标记:白色的被漏掉了。解决:CMS通过增量标记increment update的方式来解决漏标记的问题。

如何进行JVM调优?JVM参数有哪些?怎么查看一个JAVA进程的JVM参数?如果一个java程序每次运行一段时间后变得卡顿,怎么优化?

jvm通过定制运行参数提高java运行。

jvm参数可分为三类:

1.标注指令:- 开头,所有HotSpot都支持的参数,可以用java -help打印出来。

2.非标注指令:-X开头,特定的HotSpot,可用java -X打印出来。

3.不稳定参数:-XX开头,特定的HotSpot,并且变化大。

相关推荐
计算机学姐6 分钟前
基于SpringBoot的小型民营加油站管理系统
java·vue.js·spring boot·后端·mysql·spring·tomcat
小雅痞11 分钟前
[Java][Leetcode middle] 151. 反转字符串中的单词
java·leetcode
ThomasChan12313 分钟前
Win10 安装单机版ES(elasticsearch),整合IK分词器和安装Kibana
java·大数据·elasticsearch·搜索引擎·全文检索·jenkins·es
向哆哆31 分钟前
Eclipse Java 开发调优:如何让 Eclipse 运行更快?
java·ide·eclipse
爱晒太阳的小老鼠37 分钟前
策略模式-枚举实现
java·策略模式
77tian44 分钟前
设计模式的原理及深入解析
java·开发语言·单例模式·设计模式·代理模式·享元模式·原型模式
会飞的架狗师1 小时前
【Spring Cloud Gateway】Nacos整合遇坑记:503 Service Unavailable
java·开发语言
重生之后端学习2 小时前
02-前端Web开发(JS+Vue+Ajax)
java·开发语言·前端·javascript·vue.js
字节源流8 小时前
关于maven的依赖下不下来的问题
java·maven
pjx9879 小时前
服务间的“握手”:OpenFeign声明式调用与客户端负载均衡
java·运维·spring·负载均衡