JVM底层运行原理(上)

本文介绍了JVM的整体结构,包括类加载器、运行时数据区和执行引擎等组成部分。类加载器按照双亲委派模型工作,加载过程包括加载、链接(验证、准备、解析)和初始化。运行时数据区包括程序计数器、方法区、Java虚拟机栈、本地方法栈和堆。方法区存储类信息,而堆是对象和数组的主要存储区域。
摘要由CSDN通过智能技术生成
  jvm是java程序的运行环境,作为一名java程序员,是肯定要理解的。有不对的请留言,一定改。

1.JVM整体介绍

  • JVM 运行流程
    图中的源程序,不仅仅只有java,比如scale等,也可以作为源程序。
    java语音之所以是跨平台的,就是因为有JVM。
    在这里插入图片描述

  • JVM整体结构
    主要由类加载器,运行时数据区,执行引擎,本地方法等组成。
    在这里插入图片描述

2.JVM组成介绍

  • 类加载器(ClassLoader)
    jvm中有四类加载器,按优先级分别是启动类加载器(加载rt.jar),扩展类加载器(加载/lib/ext文件夹里面的jar),应用类加载器(我们的应用程序就是由它加载)和自定义类加载器。类加载采用的
  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
JVMJava虚拟机)内存模型是Java程序运行时的内存分配和管理方式。它包括了不同的内存区域,每个区域都有不同的作用和生命周期。下面是JVM内存模型的底层原理: 1. 程序计数器(Program Counter Register):程序计数器是一块较小的内存区域,它保存着当前线程执行的字节码指令的地址。在多线程环境下,每个线程都有自己独立的程序计数器,互不影响。 2. Java虚拟机栈(Java Virtual Machine Stacks):每个线程在运行时都会创建一个栈,用于存储局部变量、方法参数、返回值和方法调用的信息。栈是线程私有的,它的生命周期与线程相同。 3. 本地方法栈(Native Method Stack):本地方法栈与Java虚拟机栈类似,但是它为本地方法(使用其他语言编写的方法)服务。 4. Java堆(Java Heap):Java堆是Java虚拟机管理的最大的一块内存区域,用于存储对象实例。所有的对象实例和数组都在堆上分配内存。 5. 方法区(Method Area):方法区用于存储类的结构信息,包括类的字段、方法、构造方法、接口等。方法区也包含运行时常量池,用于存储编译期生成的各种字面量和符号引用。 6. 运行时常量池(Runtime Constant Pool):运行时常量池是方法区的一部分,用于存储编译期生成的各种字面量和符号引用。 7. 直接内存(Direct Memory):直接内存并不是虚拟机运行时数据区的一部分,它是在堆外分配的内存,通过使用ByteBuffer类来操作。直接内存的分配不受Java堆大小的限制,但是它的分配和释放需要手动管理。 以上是JVM内存模型的底层原理。通过合理地管理和优化这些内存区域,可以提高Java程序的性能和稳定性。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值