JVM实战笔记 第一周 内存区域(文中多数知识来源学习专栏,本文仅作笔记记录)

1,存放类的 方法区
方法区是在JDK1.8以前的版本里,代表JVM中的一块区域。
主要是放从.class文件里加载的类,和一些类似常量池的东西
1.8以后改名为”Metaspace“,可以认为是”元数据空间“,还是存放我们自己写的各种类相关的信息
2 执行代码指令用的程序计数器
方法区的中加载的类,实际是字节码文件,存放的是计算机可以执行的字节码指令。JVM则会使用自己的字节码执行引擎来执行它。那么在执行指令的时候九九需要一个特殊的内存区域–”程序计数器“
程序计数器就是用来记录当前执行的字节码指令的位置的,看执行到了哪条字节码指令。
因为JVM是支持多线程的,所以会有多个线程来执行不同的代码指令,每个线程都会有自己的程序计数器。
3 JAVA虚拟机栈

pubilc class kafka{
	public static void main(){
		RelicaManager replocaManager=new RelicaManager();
		replocaManager.loadReplicasFromDisk();
	}
}

这段代码中 main方法就有一个replocaManager局部变量,是引用一个RelicaManager实例对象,
因此JVM必须有一块区域来保持方法内的局部变量等数据,即–JAVA虚拟机栈。
每个线程都有自己的JAVA虚拟机栈,当线程执行了一个方法,就会对该方法调用创建对应的栈帧。
栈帧里有这个方法的局部变量表,操作数栈,动态连接,方法出口等
比如main方法执行后,就会有一个main方法的栈帧,并被压入java虚拟机栈。
同时在main方法的栈中中会存放对应的replicaManager局部变量
当main线程继续执行RelicaManager对象中的方法,就会有loadReplicasFromDisk这个栈帧以及它对应的局部变量
也被压入虚拟机栈。当方法执行完毕后,又会出栈。
4 java堆内存
存放我们在代码中创建的各种对象
new RelicaManager();就创建了一个对象实例,它会包含一些数据
当main方法中传教这个对象时,就会在main方法对应的栈帧的局部变量表中让一个引用类型的”replocaManager”局部变量来存放RelicaManager对象在堆内存中的地址
总结:
在这里插入图片描述
如图,首先JVM进程会启动,就会先加载Kaflka类到内存里,然后有一个main线程,开始执行main方法。
main线程是关联了一个程序计数器的,,它执行到哪一行指令就会记录在这里。
其次,就是main线程在执行main方法的时候会在,main线程关联的java虚拟机栈里,压入一个main方法的栈帧,
接着会发现需要创建一个ReplocaManager类的实例对象,此时会加载ReplocaManager类到内存里来。
然后回创建ReplocaManager的对象实例分配在JAVA的堆内存里。并且在main方法的栈帧里的局部变量表引入一个replocaManager 变量,让他引用ReplocaManager对象在jaba堆内存中的地址。
接着,main线程开始执行ReplocaManager对象中的方法。会一次把执行到的方法对应的栈帧压入自己的虚拟机栈。执行完后再把对应的栈帧从虚拟机栈了出栈。

5 其他内存区域
JDK很多底层API里,比如IO,NIO,Socket相关源码很多部署JAVA代码了。而是走的native方法去调用的而本地方法。
比如: public native int hasnCode();
调用这种方法的时候,就会有线程对应的本地方法栈。跟虚拟机栈类似,存放方法的局部变量表等。

还要一个不属于JVM的区域。 通过NIO中的allocateDirect这种API可以在Java堆外分配内存空间,让后通过DirectByteBuffer来引用和操作内外内存空间。某些场景下堆外内存分配可以提升性能。

注:tomcate这种web容器的类加载器打破的双亲委派机制,
在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值