JVMLog技术原理及用法是什么

本篇文章为大家展示了JVM Log技术原理及用法是什么,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。

成都创新互联专业为企业提供达茂旗网站建设、达茂旗做网站、达茂旗网站设计、达茂旗网站制作等企业网站建设、网页设计与制作、达茂旗企业网站模板建站服务,10多年达茂旗做网站经验,不只是建网站,更提供有价值的思路和整体网络服务。

介绍一下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 Log技术原理及用法是什么,你们学到知识或技能了吗?如果还想学到更多技能或者丰富自己的知识储备,欢迎关注创新互联行业资讯频道。


文章名称:JVMLog技术原理及用法是什么
网站网址:http://azwzsj.com/article/pjgpih.html