java源代码编译成字节码.class文件(JVM会给.class信息分配一个区域(数据区),去存储他的信息),文件会被加载到内存中,成为JVM进程。
如图:
JVM运行起来会有很多的数据区域
一、线程共享部分(所有线程都会访问这块内存区域,随着虚拟机和GC的创建和销毁)
1)、方法区:将class信息放到方法区里面。比如一些类信息、常量、静态变量、编译后的代码等数据。
2)、堆内存:分为老年代、新生代(Eden、From Survivor、To Survivor)。比如:方法区有了class类了,就可以根据class类就可以去创建对象,放到堆内存里面(包括垃圾回收)。
二、线程独占部分(每个线程都会有他独立的空间,随线程生命周期创建和销毁)
1)、虚拟机栈:每个线程都在这个空间有一个私有的空间,虚拟机栈由多个栈帧组成。栈帧内容包括:局部变量表、操作数栈、动态链接、方法返回地址、附加信息等等。
2)、本地方法栈:本地方法栈和虚拟机栈类似,虚拟机栈是为执行java方法而准备的,本地方法栈是为虚拟机使用Native本地方法而准备的。
3)、程序计数器:
程序计数器记录当前线程执行字节码文件,相当于代码执行的位置。CPU同一时间只会执行一条线程中的指令,多线程轮流切换并分类多线程时间。为了线程切换后,需要通过程序计数器来恢复正确的位置。
示例:
我们将Demo1.java进行解析,解析成.class文件,接着用javap命令查看解析结果,如下:
class内容-程序入口main方法
详解如下:
将字节码放进操作数栈
根据字节码指令顺序
0:将500放到操作数栈
3:将500放到本地变量表
4:将100放到操作数栈
6:将100放到本地变量表
7:将序号为1的本地变量表压到操作数栈
8:将序号为2的本地表量表压到操作数栈
9:将栈顶两int类型相除,结果入栈
15:方法调用
18和19:将本地变量表3和4序号压入到操作数栈
21:相加