ToB企服应用市场:ToB评测及商务社交产业平台

标题: 一文了解JVM面试篇(上) [打印本页]

作者: 河曲智叟    时间: 2024-6-1 15:53
标题: 一文了解JVM面试篇(上)
Java内存地区

1、如何解释 Java 堆空间及 GC?

当通过 Java 下令启动 Java 进程的时间,会为它分配内存。内存的一部分用于创建
堆空间,当程序中创建对象的时间,就从对空间中分配内存。GC 是 JVM 内部的一
个进程,回收无效对象的内存用于将来的分配。
2、JVM 的主要组成部分及其作用?

组成部分:


作用:

首先通过编译器把 Java 代码转换成字节码,类加载器(ClassLoader)再把字节
码加载到内存中,将其放在运行时数据区(Runtime data area)的方法区内,而
字节码文件只是 JVM 的一套指令集规范,并不能直接交给底层操纵系统去实行,因
此需要特定的下令解析器实行引擎(Execution Engine),将字节码翻译成底层系统
指令,再交由 CPU 去实行,而这个过程中需要调用其他语言的本地库接口(Native
Interface)来实现整个程序的功能。
3、Java 程序运行机制具体说明

Java 程序运行机制步骤


从上图可以看,java 文件通过编译器变成了.class 文件,接下来类加载器又将这
些.class 文件加载到 JVM 中。
其实可以一句话来解释:类的加载指的是将类的.class 文件中的二进制数据读入到
内存中,将其放在运行时数据区的方法区内,然后在堆区创建一个java.lang.Class
对象,用来封装类在方法区内的数据结构。
4、JVM 内存模型

Java 虚拟机在实行 Java 程序的过程中会把它所管理的内存地区划分为多少个差别
的数据地区。这些地区都有各自的用途,以及创建和销毁的时间,有些地区随着虚
拟机进程的启动而存在,有些地区则是依靠线程的启动和竣事而建立和销毁。Java
虚拟机所管理的内存被划分为如下几个地区:


深拷贝和浅拷贝

利用深拷贝的环境下,释放内存的时间不会因为出现浅拷贝时释放同一个内存的错
误。
堆栈的区别

物理地址

内存分别

存放的内容

例如:
程序的可见度

Java 中堆和栈的区别

JVM 中堆和栈属于差别的内存地区,利用目的也差别。栈常用于保存方法帧和局部
变量,而对象总是在堆上分配。栈通常都比堆小,也不会在多个线程之间共享,而堆
被整个JVM 的所有线程共享。
队列和栈是什么?有什么区别?

队列和栈都是被用来预存储数据的。
虚拟机栈(线程私有)


程序计数器(线程私有)

一块较小的内存空间, 是当火线程所实行的字节码的行号指示器,每条线程都
要有一个独立的程序计数器,这类内存也称为“线程私有” 的内存。
正在实行 java 方法的话,计数器记录的是虚拟机字节码指令的地址(当前指
令的地址) 。假如还是 Native 方法,则为空。这个内存地区是唯一一个在
虚拟机中没有规定任何 OutOfMemoryError 环境的地区。
什么是直接内存?

直接内存并不是 JVM 运行时数据区的一部分, 但也会被频仍的利用: 在JDK 1.4 引入
的 NIO 提供了基于 Channel 与 Buffer 的 IO 方式, 它可以利用 Native 函数库直接
分配堆外内存, 然后利用 DirectByteBuffer 对象作为这块内存的引用进行操纵(详见:
Java I/O 扩展), 这样就避免了在 Java 堆和 Native 堆中来回复制数据, 因此在一些
场景中可以显著进步性能。


免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。




欢迎光临 ToB企服应用市场:ToB评测及商务社交产业平台 (https://dis.qidao123.com/) Powered by Discuz! X3.4