JVM 的主要组成部分及其作用?

在这里插入图片描述
JVM 的主要组成部分及其作用?
JVM包含两个子系统和两个组件,两个子系统为 (类装载)、执行引擎);两个组件为 (运行时数据区)、 (本地接口)。
类装载:根据给定的全限定类名(如:java.lang.Object)来装载class文件到运行时数据区的方法区。执行引擎:执行classes中的指令。本地接口:与本地库接口交互 运行时数据区域:就是JVM的内存。
作用 :首先通过编译器把 Java 代码转换成字节码,类加载器(ClassLoader)再把字节码加载到内存中,将其放在运行时数据区(Runtime data area)的方法区内,需要特定的命令解析器执行引擎(Execution En

  1. List item

gine),将字节码翻译成底层系统指令,再交由 CPU 执行,这个过程需要调用其他语言的本地库接口(Native Interface)来实现整个程序的功能
JVM 运行时数据区包括哪些?
程序计数器:当前线程的行号指示器, Java 虚拟机栈存储局部变量表、操作数栈、方法出口等信息;本地方法栈与虚拟机栈的作用一样,只不过虚拟机栈是服务 Java 方法的,而它是为虚拟机调用 Native 方法服务;Java 堆Java 虚拟机中内存最大的一块,是被所有线程共享的,几乎所有的对象实例都在这里分配内存;方法区用于存储已被虚拟机加载的类信息、常量、静态变量等数据。
堆栈的区别
堆的物理地址分配对对象是不连续的。性能慢;栈使用的是数据结构中的栈,先进后出,物理地址分配是连续的。性能快。堆存放的是对象的实例和数组;;;栈存放:局部变量,操作数栈,返回结果。关注的是程序方法的执行。
队列和栈是什么?有什么区别?
队列和栈都是被用来存储数据;队列在队尾入队,队头出队;栈的进栈和出栈都在栈顶进行的,无法对栈底进行操作。
并发安全问题在虚拟机中创建对象是非常频繁的行为,在并发情况下不安全,可能出现正在给对象 A 分配内存,指针还没来得及修改,对象 B 又同时使用了原来的指针来分配内存的情况。解决这个问题有两种方案:分配内存空间进行同步处理(采用 CAS + 失败重试来保障更新操作的原子性);2、把内存分配按照线程划分在不同的空间进行,哪个线程要分配内存,就在哪个线程的 TLAB 上分配。只有 TLAB 用完并分配新的 TLAB 时,才需要同步锁。通过-XX:+/-UserTLAB参数来设定虚拟机是否使用TLAB。

Java垃圾回收机制JVM中,有一个垃圾回收线程,在虚拟机空闲或者堆内存不足时,会触发执行,扫描那些没有被引用的对象,将它们添加到要回收的集合中,回收。垃圾回收有分代复制垃圾回收、标记垃圾回收、增量垃圾回收。
垃圾回收的优点和原理,垃圾回收机制可以防止内存泄露,有效使用能使用的内存。原理:::垃圾回收器对内存堆中已经死亡或很长时间没有用过的对象进行回收。
Java 中都有哪些引用类型?
强引用:发生 gc 的时候永远不会被回收。
软引用:有用但不是必须的对象,内存不够时会被回收。
弱引用:有用但不是必须的对象,在下一次GC时会被回收。
虚引用虚引用是无法获得对象的,虚引用的用途是在 gc 时返回一个通知。
怎么判断对象是否可以被回收?
1、 引用计数器法:为每个对象创建一个引用计数,对象引用时计数器 +1,引用被释放时计数 -1,当计数器为 0 时就可以被回收。但它不能解决循环引用的问题;2、用 GC Roots 通过引用链向下搜索,当一个对象到 GC Roots 没有任何引用链相连时,这个对象可被回收
JVM 有哪些垃圾回收算法?
标记-清除算法:标记无用对象,然后进行清除回收。缺点:效率不高,会产生垃圾碎片。
复制算法:按照容量划分二个大小相等的内存区域,当一块用完的时候将活着的对象复制到另一块上,然后再把已使用的内存空间清理掉。缺点:内存使用率不高,只使用一半。
标记-整理算法:标记无用对象,把存活的对象都移向一端,然后直接清除掉端边界以外的内存。
分代算法:根据对象存活周期的不同将内存划分为新生代和老年代,新生代基本采用复制算法,老年代采用标记整理算法。
JVM 有哪些垃圾回收器?
回收新生代的收集器包括Serial、PraNew、Parallel Scavenge,回收老年代的收集器Serial Old、Parallel Old、CMS, G1收集器用于回收整个Java堆的。
新生代垃圾回收器一般采用的是复制算法,复制算法的优点是效率高,缺点是内存利用率低;老年代回收器一般采用的是标记-整理的算法进行垃圾回收。
分代垃圾回收器是怎么工作的?
分代回收器有老年代和新生代,新生代默认的空间占比总空间的 1/3,老生代的默认占比是 2/3。
新生代young GC使用的是复制算法,新生代里有 3 个分区:Eden、幸存From区、幸存To区、,它们的默认占比是 8:1:1,它的执行流程如下:
把 Eden + 幸存From区存活的对象放入 幸存To区;清空 Eden 和 幸存From区;谁空谁为幸存From区,幸存To区 变成幸存From区。每次从 幸存From区移动到 幸存To区存活的对象,年龄就 +1,当年龄到达 15(默认配置是 15)时,升级为老年代。大对象也会直接进入老年代。
老年代当空间占用到达某个值之后就会触发Full GC进行全局垃圾收回,一般使用标记整理算法。
JVM加载Class文件的原理机制
Java中的所有类,都需要由类加载器装载到JVM中才能运行。类加载器的工作就是把class文件从硬盘读取到内存中。另外写这个程序,是不需要关心类的加载的,因为这些都是隐式装载的,
类加载方式,有两种 1、隐式装载, 对new 方式创建的对象,调用类装载器加载到jvm中,2.显式装载, 直接通过class.forname()等方法,显式加载需要的类
内存分配
对象优先在 Eden 区分配;大对象直接进入老年代
yong GC和full GC
yong GC 是指发生在新生代的 GC,因为 Java 对象大多都是朝生夕死,所有 yong GC 非常频繁,一般回收速度也非常快;
Full GC 是指发生在老年代的 GC,出现了 full GC 通常会伴随至少一次 yong gc
full GC 的速度通常比 Minor GC 慢 10 倍以上。
类加载器有哪些?
主要有四种类加载器:
启动类加载器加载核心类库,无法被java程序直接引用。
扩展类加载器加载扩展库。虚拟机会提供一个扩展库目录。该类加载器在此目录里面查找并加载 Java 类。
系统类加载器根据类的路径(CLASSPATH)来加载 Java 类。Java 应用的类基本是由它来完成加载的。可以通过 ClassLoader.getSystemClassLoader()来获取它。
用户自定义类加载器通过继承 java.lang.ClassLoader类的方式实现。
类装载的执行过程?
类装载有加载:根据查找路径找到相应的 class 文件然后导入;验证:检查加载的 class 文件的正确性;准备:给类中的静态变量分配内存空间;解析:虚拟机将常量池中的符号引用替换成直接引用的过程。符号引用就理解为一个标示,而在直接引用直接指向内存中的地址;
初始化:对静态变量和静态代码块执行初始化工作。
什么是双亲委派模型?
类加载器收到了类加载的请求,它首先不会自己去加载这个类,而是把这个请求委派给父类加载器去完成,每一层的类加载器都是这样,最后所有的加载请求都会被传送到启动类加载器中,只有当父加载无法完成加载请求,子加载器才会尝试去加载类。
说一下 JVM 调优的工具?
监控工具,位于 JDK 的 bin 目录下,有 jconsole 和 jvisualvm。jconsole:用于对 JVM 中的内存、线程和类进行监控;jvisualvm:因为他是那个JDK 自带的,可以分析:内存快照、线程快照、、gc 变化等。
常用的 JVM 调优的参数都有哪些?
-Xms2g:初始化堆大小为 2g;
-Xmx2g:堆最大内存为 2g;
–XX:+UseParNewGC:使用 ParNew + Serial Old 垃圾回收器;
-XX:+UseParallelOldGC:使用 ParNew + ParNew Old 垃圾回收器;
-XX:+PrintGC:打印 gc 信息;
-XX:+PrintGCDetails:打印 gc 详细信息。

  • 2
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值