当前位置 : 主页 > 编程语言 > java >

HotSpot VM启动时JNI_CreateJavaVM方法执行步骤

来源:互联网 收集:自由互联 发布时间:2023-02-04
1、确保只有一个线程调用这个方法并且确保只创建一个HotSpot VM实例。因为HotSpot VM创建的静态数据结构无法再次初始化,所以一旦初始化达到某个确定点后,进程空间里就只能有一个

1、确保只有一个线程调用这个方法并且确保只创建一个HotSpot VM实例。因为HotSpot VM创建的静态数据结构无法再次初始化,所以一旦初始化达到某个确定点后,进程空间里就只能有一个HotSpot VM。HotSpot VM的启动至此已经无法扭转;

2、检查并确保支持当前的JNI版本,初始化垃圾收集日志的输出流;

3、初始化OS模块,如随机数生成器(Random Number Generator)、当前进程id(Current Process id)、高精度计时器(High-Resolution Timer)、内存页尺寸(Memory Page Sizes)、保护页(Guard Pages)。保护页是不可访问的内存页,用作内存访问区域的边界。例如,操作系统常在线程栈顶压入一个保护页以保证引用不会超出栈的边界。

4、解析传入JNI_CreateJavaVM的命令行选项,保存以备将来使用;

5、初始化标准的Java系统属性,例如java.version、java.vendor、os.name等;

6、初始化支持同步、栈、内存和安全点页的模块;

7、加载libzip、libnpi、libjava及libthread等库;

8、初始化并设置信号处理器(Signal Handler);

9、初始化线程库;

10、初始化输出流日志记录器(Logger);

11、如果用到Agent库(hprof、jdi),则初始化并启动;

12、初始化线程状态(Thread State)和线程本地存储(Thread Local Storage),它们存储了线程私有数据;

13、初始化部分HotSpot VM全局数据,例如事件日志(Event Log),OS同步原语、perfMemory(性能统计数据内存),以及chunkPool(内存分配期);

14、至此,HotSpot VM可以创建线程了。创建出来的Java版main线程被关联到当前操作系统的线程,只不过还没有添加到已知线程列表中;

15、初始化并激活Java级别的同步;

16、初始化启动类加载器(Bootclassloader)、代码缓存、解释器、JIT编译器、JNI、系统词典(System Dictionary)及universe(一种必备的全局数据结构集)。universe是HotSpot VM的一种重要的全局数据结构,里面包含了一系列与Java对象存储相关的重要全局数据结构。universe这种叫法源自SmallTalk,所谓“universe of objects”,本质上就是用来存储所有对象的东西的概念。在HotSpot VM里,universe类是一个静态类,里面是GCheap、SystemDictionary等与Java对象存储相关的重要结构的引用;

17、现在,添加Java主线程到已知线程列表中。检查universe是否正常。创建HotSpot VM Thread,它执行HotSpot VM所有的关键功能。同时发出适当的JVMTI事件,报告HotSpot VM的当前状态;

18、加载和初始化以下Java类:java.lang.String、java.lang.System、java.lang.Thread、java.lang.ThreadGroup、java.lang.reflect.Method、java.lang.ref.Finalizer、java.lang.Class以及余下的Java系统类。此时,HotSpot已经初始化完毕并可使用,只是功能还不完备。

19.启动HotSpot VM的信号处理器线程,初始化JIT编译器并启动HotSpot编译代理线程。启动HotSpot VM辅助线程(如监控线程统计抽样器)。至此,HotSpot VM已功能完备;

20.最后,生成JNIEnv对象返回调用者,HotSpot则准备相应新的JNI请求。

上一篇:DestoryJavaVM停止HotSpotVM的步骤
下一篇:没有了
网友评论