面试 JVM 八股文十问十答第三期

面试 JVM 八股文十问十答第三期

作者:程序员小白条,个人博客

相信看了本文后,对你的面试是有一定帮助的!关注专栏后就能收到持续更新!

⭐点赞⭐收藏⭐不迷路!⭐

1)说一下 JVM 的主要组成部分及其作用?

  • 类加载器(ClassLoader):负责将字节码文件加载到内存中,并生成对应的Class对象。
  • 运行时数据区(Runtime Data Area):包括方法区、堆、虚拟机栈、本地方法栈和程序计数器等。
  • 执行引擎(Execution Engine):负责执行字节码指令。
  • 垃圾回收器(Garbage Collector):负责自动回收不再使用的对象,释放内存空间。
  • JIT编译器(Just-In-Time Compiler):将热点代码(频繁执行的代码)编译成本地机器码,提高执行效率。
  • Java Native Interface(JNI):提供了与本地语言(如C、C++)交互的接口。
  • 本地方法库(Native Method Libraries):包含了与操作系统相关的一些本地方法的实现。

2)说一下 JVM 运行时数据区

  • 方法区(Method Area):用于存储类的结构信息、常量池、静态变量等。
  • 堆(Heap):用于存储对象实例,是JVM管理的最大一块内存区域。
  • 虚拟机栈(VM Stack):用于存储方法调用的局部变量、方法参数、返回值等。
  • 本地方法栈(Native Method Stack):与虚拟机栈类似,但是为本地方法服务。
  • 程序计数器(Program Counter):用于记录当前线程执行的字节码指令位置。
  • 运行时常量池(Runtime Constant Pool):存放编译期生成的各种字面量和符号引用。

3)深拷贝和浅拷贝

  • 深拷贝(Deep Copy):在拷贝对象时,不仅复制对象本身,还会递归复制对象引用的所有对象,使得拷贝后的对象与原对象完全独立。
  • 浅拷贝(Shallow Copy):在拷贝对象时,只复制对象本身,而不会复制对象引用的其他对象,拷贝后的对象与原对象共享引用对象。

深拷贝和浅拷贝的区别在于是否复制对象引用的其他对象。深拷贝可以避免对象之间的相互影响,每个对象都拥有独立的数据副本,但是拷贝过程较为复杂和耗时。而浅拷贝则只是简单地复制对象本身,对象之间仍然共享引用对象,容易导致对象之间的数据冲突。

在Java中,可以通过实现Cloneable接口并重写clone()方法来实现对象的浅拷贝,或者使用序列化和反序列化来实现对象的深拷贝。另外,也可以通过手动复制对象的属性来实现深拷贝。

4)说一下堆栈的区别?

  • 堆(Heap)是一块用于存储对象实例的内存区域,由JVM动态分配和管理。堆的大小可以通过启动参数进行调整。堆中的对象可以被所有线程访问,是线程共享的。
  • 栈(Stack)是一块用于存储方法调用的局部变量、方法参数、返回值等的内存区域。每个线程都有自己的栈,栈的大小是固定的。栈中的数据只能被所属线程访问,是线程私有的。

堆和栈的区别主要体现在以下几个方面:

  • 内存管理:堆由JVM动态分配和回收,栈由编译器自动分配和回收。
  • 大小和生命周期:堆的大小可以通过启动参数调整,生命周期较长;栈的大小是固定的,生命周期与线程相对应,方法调用结束后,栈中的数据会被自动释放。
  • 对象存储:堆存储对象实例,对象可以被多个线程访问;栈存储局部变量等方法调用相关的数据,只能被所属线程访问。
  • 内存分配方式:堆采用动态分配,对象的创建和销毁由JVM负责;栈采用静态分配,方法的调用和返回由编译器控制。

5)队列和栈是什么?有什么区别?

  • 队列(Queue)是一种先进先出(First-In-First-Out,FIFO)的数据结构,类似于排队的概念。新元素被插入到队列的尾部,而从队列中取出元素时,总是从队列的头部开始取出。
  • 栈(Stack)是一种后进先出(Last-In-First-Out,LIFO)的数据结构,类似于一摞盘子。新元素被压入栈的顶部,而从栈中取出元素时,总是从栈的顶部开始取出。

区别:

  • 插入和删除方式:队列采用先进先出的方式,插入元素在队尾,删除元素在队头;栈采用后进先出的方式,插入和删除元素都在栈顶。
  • 元素访问顺序:队列按照插入顺序访问元素,先插入的元素先被访问;栈按照插入顺序的逆序访问元素,后插入的元素先被访问。
  • 应用场景:队列常用于实现消息队列、任务调度等场景,栈常用于实现函数调用、表达式求值等场景。
  • 数据结构:队列可以用数组或链表实现,栈也可以用数组或链表实现。

6)对象的创建

在Java中,对象的创建主要有以下几个步骤:

  • 分配内存:根据对象的类型,分配一块连续的内存空间。
  • 初始化:对分配的内存空间进行初始化,设置对象的初始值。
  • 执行构造函数:调用对象的构造函数,进行进一步的初始化操作。
  • 返回对象引用:将对象的引用返回给调用者,以便后续对对象的操作。

在创建对象时,可以使用关键字new来实例化一个对象,例如ClassName obj = new ClassName()。在实例化对象时,会调用对象的构造函数进行初始化。构造函数可以有多个重载形式,用于满足不同的对象初始化需求。对象的创建和初始化是在堆中进行的,而对象的引用则存储在栈中。

7)为对象分配内存

在Java中,对象的内存分配是由JVM自动完成的。当使用关键字new创建一个对象时,JVM会在堆中分配一块连续的内存空间来存储对象的数据。JVM会根据对象的类型和大小来确定分配的内存大小,并进行对象的初始化。

8)处理并发安全问题

并发安全问题是指在多线程环境下,多个线程对共享资源进行读写操作时可能出现的数据不一致或不正确的情况。为了处理并发安全问题,可以采取以下几种方式:

  • 使用同步机制:通过使用synchronized关键字或ReentrantLock等锁机制来保证同一时间只有一个线程访问共享资源,从而避免数据竞争和并发冲突。
  • 使用原子操作类:Java提供了一些原子操作类,如AtomicIntegerAtomicLong等,它们提供了线程安全的原子操作,可以避免多线程并发操作时的数据不一致问题。
  • 使用线程安全的集合类:Java提供了一些线程安全的集合类,如ConcurrentHashMapCopyOnWriteArrayList等,它们在多线程环境下可以安全地进行读写操作。

9)对象的访问定位

在Java中,对象的访问定位是通过对象的引用来实现的。当创建一个对象时,会在堆中分配内存,并返回一个指向该对象的引用。通过引用,可以访问对象的属性和方法。引用可以存储在栈中,也可以存储在堆中的其他对象中。

10)内存溢出异常

内存溢出异常(OutOfMemoryError)是指在程序运行过程中,申请的内存超出了JVM所能分配的内存大小,导致无法继续分配内存空间的异常。内存溢出异常通常发生在以下情况:

  • 创建过多的对象:如果程序中频繁创建大量的对象,并且没有及时释放,就会导致内存溢出。
  • 递归调用导致栈溢出:如果程序中出现无限递归调用,每次递归都会占用一部分栈空间,当栈空间耗尽时,就会导致栈溢出。
  • 内存泄漏:如果程序中存在内存泄漏的情况,即对象不再使用但没有被正确释放,就会导致内存溢出。

处理内存溢出异常的方法包括:

  • 检查代码中的对象创建和销毁,确保及时释放不再使用的对象。
  • 增加JVM的堆内存大小,可以通过调整启动参数来增加堆内存大小。
  • 优化程序逻辑,减少对象的创建和占用的内存空间。
  • 使用内存分析工具,定位内存泄漏的问题,并进行修复。

开源项目地址:https://gitee.com/falle22222n-leaves/vue_-book-manage-system

前后端总计已经 900+ Star,1.5W+ 访问!

⭐点赞⭐收藏⭐不迷路!⭐

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/770724.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

vivo x fold 3Pro参数配置 vivo x fold 3Pro续航

vivo XFold3 Pro采用了顶级的AMOLED折叠屏,屏幕预计会配备一块6.53英寸的外屏以及8.03英寸的内屏,分辨率高达2K级别,屏幕支持120Hz刷新率,色彩鲜艳,视觉效果一流。不论是看电影、玩游戏还是日常使用,都能给…

碳实践|企业组织碳排放源识别方法、案例分析,及注意事项

在上一章中讲到“界、源、算、质、查”五步法实现企业组织碳的完整核算流程,本章将针对其中的“源”- “识别排放源”这一步骤来展开,主要分析其识别方法、实操案例,并列举注意事项。 企业识别碳排放源是指在组织边界内找到产生碳排放的设施,…

spark广播变量

广播变量应用场景 由于spark的应用场景通常是分布式场景,在本地集合和分布式集合关联,且本地集合不太大的场景,rdd的处理是在不同的executor中不同的分区处理的,我们定义的全局变量通常是在driver中的,在executor中并…

centos 虚拟机 增加硬盘 虚拟机centos磁盘扩容

2 在centos 7 系统中挂载磁盘 2.1 查看磁盘信息 进入centos 7系统中,输入“# df -h”命令,查看磁盘信息。 这里没有写显示新增的磁盘信息。 2.2 对新加的磁盘进行分区操作 2.2.1 查看磁盘容量和分区 2.2.2 创建分区 a. 选择新增的磁盘(这…

学点儿Java_Day10_集合框架(List、Set、HashMap)

1 简介 ArrayList: 有序(放进去顺序和拿出来顺序一致),可重复 HashSet: 无序(放进去顺序和拿出来顺序不一定一致),不可重复 Testpublic void test1() {String[] array new String[3];//List: 有序 可重复//有序: 放入顺序 与 拿出顺序一致,…

为何ChatGPT日耗电超50万度?

看新闻说,ChatGPT每天的耗电量是50万度,国内每个家庭日均的耗电量不到10度,ChatGPT耗电相当于国内5万个家庭用量。 网上流传,英伟达创始人黄仁勋说:“AI的尽头是光伏和储能”,大佬的眼光就是毒辣&#xff…

Luminar Neo:重塑图像编辑新纪元,Mac与Win双平台畅享创意之旅

在数字时代的浪潮中,图像编辑软件已成为摄影师和设计师们不可或缺的创作工具。Luminar Neo,作为一款专为Mac与Windows双平台打造的图像编辑软件,正以其卓越的性能和创新的编辑功能,引领着图像编辑的新潮流。 Luminar Neo不仅继承…

c语言编程题目:水仙花数

题目&#xff1a;水仙花数是指一个N位正整数&#xff08;N>3&#xff09;&#xff0c;它的每位上的数字的N次幂之和等于它本身。例如&#xff1a;153 1^3 5^3 3^3。要求&#xff1a;计算所有N位水仙花数。给出一个正整数N&#xff08;3 < N < 7&#xff09;&#x…

【日常linux操作命令】

文章目录 1、查看服务器信息1.1、查看内存1.2、查看磁盘1.3、查看CPU信息 2、清理内存缓存2.1、清理PageCache&#xff1a;2.2、清理Dentries和Inodes&#xff1a;2.3、同时清理PageCache、Dentries和Inodes&#xff1a;2.4、清理日志文件2.5、清理临时文件 3、查找文件3.1、查…

WPF使用外部字体,思源黑体,为例子

1.在工程中新建文件夹&#xff0c;命名为“Font"。 2.将下载好的字体文件复制到Font文件夹。 3.在工程中&#xff0c;加入静态资源 <Window.Resources><FontFamily x:Key"SYBold">/AnalyzeImage;Component/Font/#思源黑体 CN Bold</FontFamily…

2.3 Mac OS安装Python环境

Mac OS安装Python环境 和 Linux 发行版类似&#xff0c;最新版的 Mac OS X 也会默认自带 Python 2.x。 我们可以在终端&#xff08;Terminal&#xff09;窗口中输入python命令来检测是否安装了 Python 开发环境&#xff0c;以及安装了哪个版本&#xff0c;如下所示&#xff1…

解決flask-restful提示Did not attempt to load JSON data 问题

在使用flask-restfull进行API开发的时候。一旦我使用类似下面的代码从url或者form中获得参数就会出现报错&#xff1a;Did not attempt to load JSON data because the request Content-Type was not ‘application/json’。 代码如下&#xff1a; # Flask_RESTFUl数据解析 f…

机器学习神经网络由哪些构成?

机器学习神经网络通常由以下几个主要组件构成&#xff1a; 1. **输入层&#xff08;Input Layer&#xff09;**&#xff1a;输入层接受来自数据源&#xff08;例如图像、文本等&#xff09;的原始输入数据。每个输入特征通常表示为输入层中的一个节点。 2. **隐藏层&#xff…

ROS1通过rosbridge在局域网中控制turtle进行运动(PC和手机)--番外,清除浏览器缓存

在上一节的文章当中&#xff0c;因为编写好了JS文件&#xff0c;直接上传到在局域网内的浏览器当中&#xff0c;但是在本地更新的过程当中&#xff0c;无法对齐进行上传和更新&#xff0c;原因是浏览器在加载一次JS文件的时候&#xff0c;会自动将其加入到缓存当中&#xff0c;…

基于JavaScript的快递管理系统

基于JavaScript的快递管理系统 开发语言&#xff1a;Java 开发工具&#xff1a;MyEclipse 6.0.1 技术&#xff1a;Spring SpringMVC MyBatis 数据库&#xff1a;mysql 浏览器&#xff1a;IE8.0 系统展示 登陆页面 注册页面 快递员页面 派单员订单管理页面 派单员订单添…

【牛客】SQL147 筛选限定昵称成就值活跃日期的用户

描述 现有用户信息表user_info&#xff08;uid用户ID&#xff0c;nick_name昵称, achievement成就值, level等级, job职业方向, register_time注册时间&#xff09;&#xff1a; iduidnick_nameachievementleveljobregister_time11001牛客1号10002算法2020-01-01 10:00:00210…

mysql 存储过程示例

一、建表语句 SET NAMES utf8mb4; SET FOREIGN_KEY_CHECKS 0;-- ---------------------------- -- Table structure for user_info -- ---------------------------- DROP TABLE IF EXISTS user_info; CREATE TABLE user_info (id int(0) NOT NULL AUTO_INCREMENT,name varc…

网络七层模型之传输层:理解网络通信的架构(四)

&#x1f90d; 前端开发工程师、技术日更博主、已过CET6 &#x1f368; 阿珊和她的猫_CSDN博客专家、23年度博客之星前端领域TOP1 &#x1f560; 牛客高级专题作者、打造专栏《前端面试必备》 、《2024面试高频手撕题》 &#x1f35a; 蓝桥云课签约作者、上架课程《Vue.js 和 E…

每日一练:LeeCode-21、合并两个有序链表【链表+递归+非递归】

将两个升序链表合并为一个新的 升序 链表并返回。新链表是通过拼接给定的两个链表的所有节点组成的。 示例 1&#xff1a; 输入&#xff1a;l1 [1,2,4], l2 [1,3,4] 输出&#xff1a;[1,1,2,3,4,4] 示例 2&#xff1a; 输入&#xff1a;l1 [], l2 [] 输出&#xff1a;[…

【jvm】各个java版本默认的垃圾回收器

要看Java默认的垃圾回收器 可以使用以下命令 java -XX:PrintCommandLineFlags -version 各个java版本默认的垃圾回收器 从Java 1&#xff08;JDK 1.0&#xff09;开始到Java 21之间的各个Java版本默认的垃圾回收器经历了一系列的演变。以下是一些主要版本的Java默认垃圾回收…