# 1 JVM的内存区域布局
* java
代码的执行步骤有三点
* java源码
文件->编译器->字节码
文件
* 字节码
文件->JVM->机器码
* 机器码->系统
cpu执行
* JVM执行的字节码需要用类加载来载入;字节码
文件可以来自本地
文件,可以在网络上
获取,也可以实时
生成。就是说你可以跳过写java
代码阶段,直接
生成字节码交由JVM执行
* 其中Java虚拟机栈、程序计数器、Heap、本地
方法栈、
Metaspace属于JVM运行时的内存;按**是否线程共享**则可以分两类
* JAVA堆和
Metasspace元空间属于线程共享的;虚拟机栈和本地
方法栈、程序计数器是线程私有的
# 2 JVM五大数据区域介绍
* **2.1 程序计数器(Progarm Counter Register)**
* 一块较小的内存空间, 是当前线程所执行的字节码的行号指示器。线程有
一个独属的程序计数器,字节码解析工作时需要程序计数器来选取下一指令,分支、循环、
跳转等依赖它
* 正在执行java
方法线程的计数器记录的是虚拟机字节码指令的地址;如果还是Native
方法,则为空
* 程序计数器内存区域是唯一
一个在虚拟机中没有规定任何OutOfMemoryError
错误的区域
* **2.2 虚拟机栈(Virtual Machine Stack)**
* Java
方法执行的内存模型:每个
方法在执行的同时都会创建
一个栈帧(Stack Frame)用于存储局部变量表、操作数栈、动态
链接、
方法出口等信息
* 每
一个方法从
调用直至执行完成的过程,就对应着
一个栈帧在虚拟机栈中入栈到出栈的过程
* 栈帧是用来存储数据和部分过程结果的数据结构,同时也被用来处理动态
链接(Dynamic Linking)、
方法返回值和异常分派(
dispatch Exception)。栈帧随着
方法调用而创建,随着
方法结束而销毁(无论
方法是正常完成还是异常完成)
* 如果线程请求的栈深度大于虚拟机允许深度,则抛出StackOverflowError;扩展时无法申请到足够内存,则抛出OutOfMemeryError
* **2.3 本地
方法栈(Native Method Stack)**
* 本地
方法栈和虚拟机栈作用类似,区别是虚拟机栈为执行Java
方法服务,而本地
方法栈则为Native
方法服务。(HopShot的实现 直接把本地
方法栈和虚拟机栈合二为一)
* 上述3类区域,生命周期与Thread相同,即:线程创建时,相应的内存区创建,线程销毁时,释放相应内存
* **2.4 堆(Heap)**
* 线程共享的一块内存区域,几乎所有的对象实例
在这里分配内存,也是
垃圾收集器进行
垃圾收集的最重要的内存区域。因此很多时候也叫GC堆
* 线程私有的分配缓存区(Thread Local Alloaction Buffer)也是在堆划分出来的
* JDK8的版本,因使用元空间代替永久代,字符串常量池和类的静态变量也放入java堆中
* **2.5 元空间(
MetaSpace)**
* 主要存储类的元数据,比如类的各种描述信息,类名、
方法、字段、访问限制等,既编译器编译后的
代码等数据
* **运行时常量池**:Class
文件中除了有类的版本、字段、
方法等描述等信息外;还有一项信息是常量池,用于存放编译期
生成的各种字面量和符号引用,这部分将在类加载后存放到元空
间的运行时常量池中
* **使用元空间代替永久代原因**
* 永久代的大小是在启动时固定好的,很难进行调优;太大则容易导致永久代溢出;太小在运行时,容易抛出OutOfMemeryError
* 字符串存在永久代中,使用时易出问题,由于永久代内存经常不够用,爆出异常OutOfMemoryError: PermGen
* **CodeCache**
* JVM
生成的native code存放的内存空间称之为Code Cache;JIT编译、JNI等都会编译
代码到native code,其中JIT
生成的native code占用了Code Cache的绝大部分空间
* 直接内存
* 它并不是虚拟机运行时数据区的一般分,也不在规范定义。JDK1.4,引入了Channel(通道)与Buffer(缓存区)的
I/O方式,它可以使用Native
函数分配堆外内存,可通过DirectByteBuffer操作。
# 3 JVM运行时内存布局和JMM内存模型区别

* JVM内存区域是指JVM运行时将内存数据分区域存储,强调对内存空
间的划分
* JAVA内存模型是Java语言在多线程并发情况下对于
共享变量内存操作的规范:
解决变量在多线程的可见性、原子性的问题
# 总结
我个人认为,如果你想靠着背面试题来获得心仪的offer,用癞蛤蟆想吃天鹅肉形容完全不过分。想必大家能感受到面试越来越难,想找到心仪的工作也是越来越难,高薪工作羡慕不来,却又对自己目前的薪资不太满意,工作几年甚至连
一个应届生的薪资都比不上,终究是错付了,错付了自己没有去提升技术。
这些面试题
分享给大家的目的,其实是希望大家通过大厂面试题分析自己的技术栈,给自己梳理
一个更加明确的学习方向,当你准备好去面试大厂,你心里有底,大概知道面试官会问多广,多深,避免面试的时候一问三不知。
大家可以把Java基础,JVM,并发编程,
MysqL,Re
dis,Spring,Spring cloud等等做
一个知识总结以及延伸,再去进行操作,不然光记是学不会的,这里我也提供一些脑图
分享给大家:



希望你看完这篇
文章后,不要犹豫,抓紧学习,复习知识,准备在明年的金三银四拿到心仪的offer,加油,打工人!
**[领取资料只需要点击这里即可免费
获取全部资料!](https://docs.qq.com/doc/DSmxTbFJ1cmN1R2dB)**
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。