学习笔记JVMLog技术简介
本文向大家简单介绍一下JVM Log的概念,初始化和释放,JVM Log各个class的实现除了很自然地运用了继承,同时运用重载new/deleteoperator这个C++特有的技巧,也 有效地封装了JVM Log的创建和释放功能。

JVM Log简介
JVM在调试版本下,会输出hotspot.JVM Log。通过参数-XJVM Loggc:FileName,来设置GC的JVM Log。
JVM Log的实现主要在
- \hotspot\src\share\vm\utilities\ostream.hpp
- \hotspot\src\share\vm\utilities\ostream.cpp
- \hotspot\src\share\vm\utilities\xmlstream.hpp
- \hotspot\src\share\vm\utilities\xmlstream.cpp
- \hotspot\src\share\vm\utilities\defaultStream.hpp
主要的class是:outputStream、fileStream、xmlTextStream、defaultStream
继承关系是:
ResourceObj
   |
   |-- outputStream
        |
        |--- fileStream
        |
        |--- xmlTextStream
              |
              |--- defaultStream
defaultStream::instance是其他模块调用的主要接口。
JVM Log的初始化
ostream_init()初始化defaultStream::instance
 ostream_init_JVM Log()初始化JVM的DebugJVM Log和GC的JVM Log,
 其中其核心代码是:defaultStream::instance->has_JVM Log_file();它转而调用voiddefaultStream::init_JVM Log();这是真正干活的代码了。
 defaultStream::init_JVM Log的代码写的很清晰,其中只有一个C++的语法点需要注意:重载newoperator。
ostream.cppline346
 fileStream*file=new(ResourceObj::C_HEAP)fileStream(try_name);
 这是因为outputStream的父类是ResourceObj,ResourceObj重载了new和deleteoperator。关于C++语法就不多说了,太多的好书论及了这个问题。
JVM Log的最终释放
Threads::destroy_vm()
    |
    |--> exit_globals()
          |
          |--> ostream_exit()
               |
               |--> 用delete operator释放掉各个JVM Log
总结
JVM Log各个class的实现除了很自然地运用了继承,同时运用重载new/deleteoperator这个C++特有的技巧,也 有效地封装了JVM Log的创建和释放功能。
【编辑推荐】
- 新一代JVM垃圾回收算法出炉
- 探究JVM1.6与JVM1.5性能差距
- JVM监控在本地和远程的应用
- JVM参数设置使用技巧
- JVM启动参数中标准参数列表速查手册
本文标题:学习笔记JVMLog技术简介
本文URL:http://jxruijie.cn/article/dhipeei.html

 
                