Java虚拟机

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方法服务。

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值