JVM总体架构
JVM 是 java虚拟机,是用来执行java文件的
Java的跨平台及原理
跨平台:由Java编写的程序可以在不同的操作系统上运行:一次编写,多处运行
原理:编译之后的字节码文件和平台无关,需要在不同的操作系统上安装一个对应版本的虚拟机(JVM)
JVM的分类
①. 类加载子系统
②. 运行时数据区
③. 执行引擎
盗用网上的一张图如下:
- 堆(Heap): 被所有线程共享的一块内存区域,在虚拟机启动时创建。此内存区域的唯一目的就是存放对象实例,几乎所有的对象实例都在这里分配内存,也是Java虚拟机所管理的内存中最大的一块。通常配置的 -Xmx:配置堆最大内存 -Xms:配置堆最小内存.
- 方法区(Method Area): 与堆一样,是各个线程共享的内存区域,存储已被虚拟机加载的类信息、常量、静态变量、即时编译器编译后的代码等数据。
- 程序计数器(Program Counter Register): 一块较小的内存空间,一个记录着当前线程所执行的字节码的行号指示器。
- 栈(stack): 也叫虚拟机栈,同程序计数器一样,也是线程私有的,它的生命周期与线程相同。虚拟机栈描述的是Java方法执行的内存模型:每个方法被执行的时候都会同时创建一个栈帧(Stack Frame)用于存储局部变量表、操作栈、动态链接、方法出口等信息。每一个方法被调用直至执行完成的过程,就对应着一个栈帧在虚拟机栈中从入栈到出栈的过程。
- 本地方法栈(Native Method Stack): 与虚拟机栈所发挥的作用是非常相似的,其区别不过是虚拟机栈为虚拟机执行Java方法(也就是字节码)服务,而本地方法栈则是为虚拟机使用到的Native方法服务。