JVM面试总结(1)-java内存区域和内存溢出异常

本文详细介绍了JVM的内存分布,包括线程计数器、虚拟机栈、本地方法栈、Java堆、方法区以及直接内存。强调了各个区域的作用,如线程计数器用于指定字节码执行位置,堆存储对象实例,方法区存储类信息。同时,讨论了对象创建过程、内存分配策略和对象访问定位方式。最后,分析了各种类型的内存溢出异常及其原因,如堆溢出、栈溢出、常量池溢出,并列举了常见的内存泄漏情况,包括静态集合、未关闭的连接、作用域不当的变量、内部类与外部类的引用关系以及哈希值改变等。
摘要由CSDN通过智能技术生成

2.1内存分布图:
在这里插入图片描述
方法区和堆是线程共享的;
虚拟机栈,本地方法栈,程序计数器是线程私有的;
1. 线程计数器:用来指定当前线程执行字节码的行号指示器。JVM的多线程是通过线程轮流切换分配执行时间来实现的,在任何时刻,每个处理器都只会执行一个线程中的指令,当线程进行切换的时,为了线程能恢复当正确的位置,所以每个线程必须有个独立的线程计数器,这样才能保证线程之间不互相影响。字节码解释器的工作就是通过改变这个指示器的值来选取下一条需要执行的字节码指令,分支,循环,跳转,异常处理,线程恢复等基础功能都需要这个计数器来完成。
2. 虚拟机栈:生命周期与线程是相同的,描述java方法执行的内存模型。每个方法在执行的同时,都会创建一个栈帧(方法运行时的基本数据结构),用于存储局部变量表,操作数栈,动态链接,方法出入口等信息,每个方法的调用到执行完成的过程就是一个栈帧入栈到出栈的过程;局部变量表存储方法相关的局部变量,包括基本数据,对象引用和返回地址等。局部向量表在编译期就确定了。
3. 本地方法栈:与虚拟机栈执行的基本相同,一般混为一谈,统称栈,唯一的区别就是虚拟机栈是执行Java方法的,本地方法栈是执行native方法的;
4. Java堆:线程共享。主要存储对象的实例。可拓展。 逻辑连续,物理不一定连

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值