一、JVM内存结构

▷ 谈及内存结构各个部分的数据交互过程:还可以再谈及生命周期、数据共享;是否GC、是否OOM

答:jvm 内存结构包括程序计数器、虚拟机栈、本地方法栈、堆、方法区;它是字节码运行时的数据区,针对字节码,就会有一个具体的分配。

  • 对于类信息本身,需要把它存储在方法区
  • 针对字节码对应的类要执行的时候,相应的还需要new 对象,就需要在堆空间 new 对象;
  • 对应的执行过程中,都是一些方法的调用,需要在虚拟机栈分配栈帧,代表一个一个的方法的调用。
  • 在整个过程中需要用到程序计数器,来记录虚拟机栈的对应的每个线程执行到哪一行了。

■ 对应jvm内存结构各部分的生命周期,堆、方法区是和 jvm生命周期一致的;而 pc寄存器、栈、本地方法栈是和线程生命周期一致的。所以,这个堆、方法区,数据可以共享;而pc寄存器、栈、本地方法栈是线程私有的,不共享;

■ 其中堆、方法区 会GC、OOM;而pc寄存器不GC,不OOM;栈、本地方法栈不会GC,会OOM;

简图:

二、类加载

1、类的加载过程

答:类加载包括三个阶段:加载、链接、初始化,其中链接还包括了验证、准备、解析。

加载阶段:首先通过类全限定名获取到类的二进制字节流,然后将字节流对应的静态存储结构转化成方法区运行时的数据结构;接着在内存生成一个Class对象

链接阶段:验证,保证了虚拟机的安全;准备,为类变量分配内存并设置默认初始值;解析,将常量池的符号引用转化成直接引用。

初始化阶段:目的是执行类变量、静态代码块。

2、类加载器

答:官方是将类加载器分为两种:引导类加载器、自定义类加载器;详细划分的话,包括:引导类加载器、扩展类加载器、应用程序类加载器、用户自定义类加载器。

除了引导类加载器,其他类加载器都直接或或间接继承 ClassLoader;这个引导类加载器是用C或C++语言写的,用来加载Java的核心库(java、javax、sun包)

继承关系是启动类是根父类,扩展类继承它,然后应用程序类继承扩展类加载器,用户自定义的类加载器继承应用程序类加载器。

三、双亲委派机制

1、双亲委派机制

答:jvm 对 class 文件是按需加载,需要使用到该类才会把该类的class文件加载到内存生成Class对象。加载类的class文件就是使用双亲委派模式,即把请求交给父类处理。它是一种任务委派模式。

2、工作原理-向上委派

  • 如果一个类加载器收到类加载请求,它并不会自己先去加载,而是把这个请求委托给父类的加载器去执行
  • 如果父类加载器还存在其父类加载器,则进一步向上委托,依次递归,请求最终将到达顶层的启动类加载器
  • 如果父类加载器可以完成类加载任务,就成功返回,倘若父类加载器无法完成此加载任务,子加载器才会尝试自己去加载,这就是双亲委派模式。

3、双亲委派的优势

  • 避免类的重复加载
  • 保护程序安全,防止核心API被随意篡改; 这种保护作用也是"沙箱安全机制"
    • 比如自定义类:java.lang.String 和 java 核心的 String 重复且冲突了

四、对象分配

1、对象分配过程以及YGC、FGC

  • 针对幸存者s0,s1区的总结:复制之后有交换,谁空谁是to
  • 关于垃圾回收:频繁在新生区收集,很少在老年代收集,几乎不再永久代和元空间进行收集
  • 新生代采用复制算法的目的:减少内存碎片

五、了解垃圾回收

1、垃圾回收概述

(1) 什么是垃圾?

  • 垃圾:运行程序中没有任何指针指向的对象。

(2) 为什么需要GC?

  • 不GC,导致内存可能会消耗完;没有GC,不能保证应用程序的正常执行。通过gc,jvm会将整理出来的内存分配给新的对象。

2、垃圾回收相关算法

  • 标记阶段:引用计数算法、可达性分析算法 ▷识别、标记对象是死亡对象(垃圾)
  • 清除阶段:标记-清除算法、复制算法、标记-压缩算法

(1) 标记阶段的算法

■ 引用计数算法

  • 问题:循环引用,导致内存泄露

可达性分析算法

  • 思路:以根对象集合(GC Roots) 为起始点,搜索连接的目标对象是否可达,不可达,标记为垃圾对象。

    ​ 这个搜索过程走过的路径称为引用链

GC Roots可以是哪些? ▷各种引用对象(栈引用对象、本地方法栈引用对象、方法区静态属性引用对象、字符串常量池引用对象)

(2) 清除阶段的算法:

■ 标记-清除算法:

  • 标记:沿着GC roots 集合中的根节点遍历可达,可达标记为可达对象。一般是在对象的 Header 中标记为可达对象。【注意:标记的是可达对象,不是垃圾对象
  • 清除:对堆内存进行遍历,发现Header中没有标记为可达对象的,进行回收。

优缺点:

  • 优点:基础、常见
  • 缺点:效率不高;产生内存碎片;GC时,需要停止整个应用程序(STW),用户体验差。

■ 复制算法:

  • 使用前提:复制算法的高效性是建立在存活对象少、垃圾对象多的前提下的。

    • 比如新生代的对象都是"朝生夕死",幸存区就是使用的是复制算法。

优缺点:

  • 优点:没有标记和清除过程,实现简单,运行高效; 复制过去以后保证空间的连续性,不会出现“碎片”问题
  • 缺点:需要两倍的内存空间。

■ 标记-压缩(整理)算法:

优缺点:

  • 优点:消除了标记-清除算法当中,内存区域分散的缺点,消除了复制算法当中,内存减半的高额代价。
  • 缺点:从效率上来说,标记-整理算法要低于复制算法。 移动对象的同时,如果对象被其他对象引用,则还需要调整引用的地址

3、对比清除阶段三种算法效率、内存利用率:

4、堆常见面试题-说一下 MinorGC、MajorGC、FullGC 的区别?

  • Minor GC:新生代的GC
  • Major GC:老年代的GC
  • Full GC:整堆收集,收集整个Java堆和方法区的垃圾收集

Hotspot VM的GC分为两大种类型:一种是部分收集(Partial GC),一种是整堆收集(FullGC)

  • 部分收集:不是完整收集整个Java堆的垃圾收集。其中又分为:

    • 新生代收集(MinorGC/YoungGC):只是新生代的垃圾收集
  • 老年代收集(MajorGC/o1dGC):只是老年代的圾收集。

    • 混合收集(MixedGC):收集整个新生代以及部分老年代的垃圾收集。
  • 整堆收集(FullGC):收集整个java堆和方法区的垃圾收集。

如果本文对你有帮助的话记得给一乐点个赞哦,感谢!

面试~jvm(JVM内存结构、类加载、双亲委派机制、对象分配,了解垃圾回收)的更多相关文章

  1. 关于Java类加载双亲委派机制的思考(附一道面试题)

    预定义类加载器和双亲委派机制 JVM预定义的三种类型类加载器: 启动(Bootstrap)类加载器:是用本地代码实现的类装入器,它负责将 <Java_Runtime_Home>/lib下面 ...

  2. [五]类加载机制双亲委派机制 底层代码实现原理 源码分析 java类加载双亲委派机制是如何实现的

      Launcher启动类 本文是双亲委派机制的源码分析部分,类加载机制中的双亲委派模型对于jvm的稳定运行是非常重要的 不过源码其实比较简单,接下来简单介绍一下   我们先从启动类说起 有一个Lau ...

  3. 浅谈JVM-类加载器结构与双亲委派机制

    一.类加载器结构 1.引导类加载器(bootstrap class loader) 它用来加载Java的核心库(JAVA_HOME/jre/lib/rt.jar),是用原声代码来实现的,并不继承自ja ...

  4. 深入JVM系列(三)之类加载、类加载器、双亲委派机制与常见问题

    一.概述   定义:虚拟机把描述类的数据从Class文件加载到内存,并对数据进行校验.转换解析和初始化,最终形成可以被虚拟机直接使用的java类型.类加载和连接的过程都是在运行期间完成的. 二. 类的 ...

  5. 说一说JVM双亲委派机制与Tomcat

    双亲委派模型与JVM 类加载 讲个故事: 以前,爱捣鼓的小明突然灵机一动,写出了下面的代码 package java.lang; public class String { //...复制真正Stri ...

  6. [转帖]说一说JVM双亲委派机制与Tomcat

    说一说JVM双亲委派机制与Tomcat https://www.cnblogs.com/dengchengchao/p/11844022.html 讲个故事: 以前,爱捣鼓的小明突然灵机一动,写出了下 ...

  7. JVM学习六:JVM之类加载器之双亲委派机制

    前面我们知道类加载有系统自带的3种加载器,也有自定义的加载器,那么这些加载器之间的关系是什么,已经在加载类的时候,谁去加载呢?这节,我们将进行讲解. 一.双亲委派机制 JVM的ClassLoader采 ...

  8. JVM之类加载器、加载过程及双亲委派机制

    JVM 的生命周期 虚拟机的启动 Java 虚拟机的启动是通过引导类加载器(bootstrap class loader)创建一个初始类(initial class)来完成的,这个类是由虚拟机的具体实 ...

  9. JVM类加载与双亲委派机制被打破

    前言 前文已经讲了虚拟机将java文件编译成class文件后的格式:JVM虚拟机Class类文件研究分析 java文件经过编译,形成class文件,那么虚拟机如何将这些Class文件读取到内存中呢? ...

随机推荐

  1. 为什么新的5G标准将为技术栈带来更低的 TCO

    ​ 摘要 新5G标准和边缘计算对低延迟的要求,给那些试图将一堆不同组件组装成一个不会出现故障且仍具有低延迟的高成本效益应用程序公司带来了严峻的挑战.事实上,这个问题非常严重,以至于需要重新考虑架构. ...

  2. 【黑马pink老师的H5/CSS课程】(一)基本介绍

    视频P4~P6 黑马程序员pink老师前端入门教程,零基础必看的h5(html5)+css3+移动 1.网页 1.1 什么是网页 网站是网页的集合,网页是构成网站的基本元素,常用html格式文件 1. ...

  3. idea启动java Maven项目,出现" java: 程序包xxxx不存在"

    解决办法如下:将idea的构建和运行托管到maven下面

  4. NC17857 起床困难综合症

    NC17857 起床困难综合症 题目 题目描述 21 世纪,许多人得了一种奇怪的病:起床困难综合症,其临床表现为:起床难,起床后精神不佳.作为一名青春阳光好少年,atm 一直坚持与起床困难综合症作斗争 ...

  5. Tapdata肖贝贝:实时数据引擎系列(三) - 流处理引擎对比

      摘要:本文将选取市面上一些流计算框架包括 Flink .Spark .Hazelcast,从场景需求出发,在核心功能.资源与性能.用户体验.框架完整性.维护性等方面展开分析和测评,剖析实时数据框架 ...

  6. .NetCore|.Net6 gRPC服务开发及本地调试

    前言 最近在项目中实装应用了gRPC技术,本着能把技术描述出来给别人能看的懂的思想及作为自己学习笔记的心态编写了此文.因为在实际项目中是webApi接口和gRPC接口使用在同一项目服务中,所以本文的例 ...

  7. python测试开发django-197.django-celery-beat 定时任务

    前言 django-celery-beat 可以支持定时任务,把定时任务写到数据库. 接着前面这篇写python测试开发django-196.python3.8+django2+celery5.2.7 ...

  8. NOI / 1.4编程基础之逻辑表达式与条件分支讲解-02:输出绝对值

    02:输出绝对值 总时间限制: 1000ms 内存限制: 65536kB 题目: 描述 输入一个浮点数,输出这个浮点数的绝对值. 输入 输入一个浮点数,其绝对值不超过10000. 输出 输出这个浮点数 ...

  9. 循环队列(严3.30)--------西工大NOJ习题.9

    #define _CRT_SECURE_NO_WARNINGS #include <stdio.h> #include <stdlib.h> typedef struct _Q ...

  10. 出现 Expected 0 arguments but found 1 的bug原因

    问题:在给FileInputStream传入参数时报错 原以为是导错了包,结果试了几次都不行,最后才发现是项目名和这个方法名重复了,修改项目名就可以了! 红线出只是异常,抛出即可解决