jvm小结

JVM

在这里插入图片描述

jvm的主要组成部分?及其作用
  • 类加载器(ClassLoader):加载类文件到内存。Class loader只管加载,只要符合文件结构就加载,至于能否运行,它不负责,那是有Exectution Engine 负责的。

  • 运行时数据区(Runtime Data Area): 这就是我们常说的JVM的内存模型。

    介绍:类加载器加载我们的class字节码文件,把读取的信息翻译成类信息存放到我们的方法区,同时在中生成该类的Class对象,当我们程序运行调用方法时,局部变量、对象引用、数组引用会在虚拟机栈中生成,如果在方法调用中需要new对象,则会在堆中根据Class信息生成对象,最后由我们的字节码执行引擎解释执行方法区的代码块,就完成了我们的代码执行。当然这个过程中,涉及到线程的切换,这时程序计数器就派上用场了,它会记录当前线程执行到哪一行代码,下次该线程再次获取cpu执行权时,继续从该行代码继续执行,最后本地方法栈和虚拟机栈的功能几乎一模一样,只不过它是执行的native本地方法,底层是调用的C或C++代码

  • 执行引擎(Execution Engine):执行classes中的指令。

  • 本地库接口(Native Interface):与native libraries交互,是其它编程语言交互的接口。

JAVA程序运行机制

在这里插入图片描述

如何理解Java程序一次编写,处处运行?

Java程序运行在JVM(Java虚拟机)中,而JVM是运行在操作系统之上,JVM内部做了不同操作系统之间的适配

jvm内存模型详细介绍

原文链接:https://blog.csdn.net/sermonlizhi/article/details/124774141

  • 堆(heap):JVM管理的最大一块内存空间,它是所有线程所共享的一块区域。在虚拟机启动的时候创建,该区域的唯一目的就是为了存放对象实例,几乎所有通过new创建的实例对象都会被分配在该区域
  • 方法区(methodArea):在JDK 8之前,方法区也称之为永久代,这部分区域方法区与堆一样,是各个线程共享的内存区域,它用于存储已被虚拟机加载的类型信息、常量、静态变量、即时编译器编译后的代码缓存等数据。
  • 栈(stack):是JVM中每个线程所私有的一块空间,每个线程都会有这么一块空间。它的生命周期是与线程的生命周期是绑定的。虚拟机栈描述了Java中方法执行时的内存模型,即每个方法被执行的时候,线程都会在自己的线程栈中同步创建一个栈帧(Stack Frame),用于存放局部变量表、操作数栈、动态连接和方法出口等信息,每个方法从调用到完成的过程,就对应着一个栈帧在线程栈中从入栈到出栈的过程
  • 本地方法栈(native method stack):本地方法栈与虚拟机栈的作用是相似,不同的是虚拟机栈为JVM执行的Java方法服务,而本地方法栈为JVM调用的本地方法服务。HotSpot虚拟机直接把本地方法栈和虚拟机栈合二为一
  • 程序计数器(pc register):只需要占用一小块的内存空间,每个线程都会有自己独立的程序计数器,主要功能就是记录当前线程执行到哪一行指令了,可以看作是当前线程所执行的字节码行号指示器。
Java内存模型

Java 内存模型(JMM)是一种抽象的概念,并不真实存在,它描述了一组规则或规范,通过这组规范定义了程序中各个变量(包括实例字段、静态字段和构成数组对象的元素)的访问方式。试图屏蔽各种硬件和操作系统的内存访问差异,以实现让 Java 程序在各种平台下都能达到一致的内存访问效果。
注意:整个Java内存模型实际上是围绕着三个特征建立起来的一组规则。分别是:原子性,可见性,有序性。这三个特征可谓是整个Java并发的基础

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值