首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

Java底层-执行引擎

先回忆一下前面几节内容:一个.java文件经Javac编译器编译为.class文件(字节码文件), 当我们使用java命令执行该class文件时(HotSpot为例),首先会创建JVM实例,开辟内存空间,然后由类加载器将相应的字节码文件加载到虚拟机内存中,最后找到程序执行入口的main函数, 由JVM创建的main线程调用main函数(线程为执行引擎的的一个实例,并为该线程绑定程序计数器,虚拟机栈),main函数调用的过程中会先创建一个main帧,根据编译时期就已经确定的局部变量数组和操作数栈的大小分配内存空间, 将内存空间清零,将main帧压入main线程虚拟机栈中,main帧执行过程中,如遇到其他方法调用,同样会将调用的方法封装为栈帧压入栈中。

04
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    Java底层-运行时数据区

    在前面关于HotSpot组成中提到,运行时数据区就类似一个工厂,是Java程序运行所在的内存区域,这个区域被JVM所管理,按照虚拟机规范的规定将其划分为:方法区、堆、程序计数器,虚拟机栈、本地方法栈五个部分(在HotSpot虚拟机中虚拟机栈和本地方法栈功能上已经合并) 其中方法区和堆在JVM实例创建的时候就开始创建且分配好内存,我们在启动程序过程中可以通过一些参数设置,比如通过-Xms、-Xmx设置堆大小, JDK7中通过-XX:PermSize、-XX:MaxPermSize设置方法区大小(永久代),JDK8通过-XX:MetaspaceSize=N和 -XX:MaxMetaspaceSize=N设置方法区大小(元空间), 而程序计数器,虚拟机栈,本地方法栈是在线程创建时进行分配,所以方法区、堆是线程共享的,而程序计数器、虚拟机栈、本地方法栈是和线程绑定的,是线程私有的。

    01
    领券