jvm 虚拟机日志参数


jvm 虚拟机日志参数

 

官网:https://docs.oracle.com/en/java/javase/14/docs/specs/man/java.html#advanced-runtime-options-for-java

 

 

*******************************

-Xlog 命令格式

 

-Xlog[:[selections][:[output][:[decorators][:output-options]]]]

 

-Xlog:开启日志输出,默认为-Xlog:all=warning:stdout:uptime,level,tags

-Xlog:help:查看-Xlog参数使用方式

-Xlog:disable:禁用-Xlog日志输出

 

常用日志参数

-Xlog:gc:输出gc日志

-Xlog:gc*:输出详细gc日志

-Xlog:gc+heap=debug:输出gc前后堆信息,等同于-XX:+PrintHeapAtGC,java9及之后使用

-Xlog:safepoint:输出gc过程中用户线程并发及停顿时间

-Xlog:gc+age=trace:输出gc、新生代对象年龄

 

 

**********************

selections:tags + level,可选

 

tags

Available log tags:
 add, age, alloc, annotation, aot, arguments, attach, barrier, biasedlocking, blocks, 
bot, breakpoint, bytecode, cds, census, class, classhisto, cleanup, codecache, 
compaction, compilation, constantpool, constraints, container, coops, cpu, cset, data, 
datacreation, dcmd, decoder, defaultmethods, director, dump, dynamic, ergo, event, 
exceptions, exit, fingerprint, free, freelist, gc, handshake, hashtables, heap, 
humongous, ihop, iklass, init, inlining, install, interpreter, itables, jfr, jit, jni, 
jvmti, liveness, load, loader, logging, malloc, mark, marking, membername, memops, 
metadata, metaspace, methodcomparator, mirror, mmu, module, monitorinflation, 
monitormismatch, nestmates, nmethod, normalize, numa, objecttagging, obsolete, oldobject, 
oom, oopmap, oops, oopstorage, os, pagesize, parser, patch, path, perf, periodic, phases, 
plab, preorder, preview, promotion, protectiondomain, ptrqueue, purge, record, redefine, 
ref, refine, region, reloc, remset, resolve, safepoint, sampling, scavenge, setting, smr, 
stackmap, stacktrace, stackwalk, start, startuptime, state, stats, streaming, 
stringdedup, stringtable, subclass, survivor, sweep, symboltable, system, table, task, 
thread, time, timer, tlab, tracking, unload, unshareable, update, verification, verify, 
vmmutex, vmoperation, vmthread, vtables, vtablestubs, workgang

 Specifying 'all' instead of a tag combination matches all tag combinations.

 

level: off, trace, debug, info, warning, error

 

示例:

all:包含所有标签

gc:只有gc标签的日志

gc*:包含gc的标签

gc + phases:只有gc、phrases的日志,单独的gc、phases不输出

gc + phases*:输出包含gc、phases的日志

 

gc=trace:输出日志级别在trace或以上的日志

 

 

**********************

output:输出位置

 

stdout:输出到控制台

stderr:错误输出

file=file_name:输出到文件

 

 

**********************

decorations:日志输出格式,可选,默认为uptime,level,tags

 

time、t:当前时间,当前时区时间,如:[2020-04-02T16:17:54.614+0800]

utctime、utc:通用时间,0时区时间,如:[2020-04-02T08:17:54.614+0000]

timemills、tm:System.currentTimeMillis()的数值,如:[1585815474614ms]

timenanos、tn:System.nanoTime()的数值,如:[108171620762600ns]

 

uptime、u:虚拟机启动到当前时间间隔,如:[0.179s]

uptimemillis、um:虚拟机启动经过的毫秒数,如:[171ms]

uptimenanos、un:虚拟机启动到当前经过的时间,纳秒,如:[108303677015300ns]

 

hostname、hn:主机名

pid、p:进程id

tid、ti:线程id

level、l:日志级别

tags、tg:标签名

 

 

*******************************

示例

 

public class Test {

    public static void main(String[] args){
        byte[] b=new byte[1024*1024];
        b=null;

        System.gc();
    }
}

 

**********************

控制台输出

 

虚拟机参数:-XX:+UseParallelGC -Xlog:gc*:stdout:time,utc,uptime,hostname,pid,tid,level,tags

[2020-04-02T16:30:54.480+0800][2020-04-02T08:30:54.480+0000][0.027s][LAPTOP-D73GD8TE][6480][1664][info][gc,heap,coops] Heap address: 0x0000000081c00000, size: 2020 MB, Compressed Oops mode: 32-bit
[2020-04-02T16:30:54.483+0800][2020-04-02T08:30:54.483+0000][0.028s][LAPTOP-D73GD8TE][6480][1664][info][gc           ] Using Parallel
[2020-04-02T16:30:54.600+0800][2020-04-02T08:30:54.600+0000][0.146s][LAPTOP-D73GD8TE][6480][4388][info][gc,start     ] GC(0) Pause Young (System.gc())
[2020-04-02T16:30:54.602+0800][2020-04-02T08:30:54.602+0000][0.148s][LAPTOP-D73GD8TE][6480][4388][info][gc,heap      ] GC(0) PSYoungGen: 9472K(38400K)->968K(38400K) Eden: 9472K(33280K)->0K(33280K) From: 0K(5120K)->968K(5120K)
[2020-04-02T16:30:54.602+0800][2020-04-02T08:30:54.602+0000][0.148s][LAPTOP-D73GD8TE][6480][4388][info][gc,heap      ] GC(0) ParOldGen: 0K(87552K)->8K(87552K)
[2020-04-02T16:30:54.602+0800][2020-04-02T08:30:54.602+0000][0.148s][LAPTOP-D73GD8TE][6480][4388][info][gc,metaspace ] GC(0) Metaspace: 624K(4864K)->624K(4864K) NonClass: 566K(4352K)->566K(4352K) Class: 58K(512K)->58K(512K)
[2020-04-02T16:30:54.602+0800][2020-04-02T08:30:54.602+0000][0.148s][LAPTOP-D73GD8TE][6480][4388][info][gc           ] GC(0) Pause Young (System.gc()) 9M->0M(123M) 1.999ms
[2020-04-02T16:30:54.602+0800][2020-04-02T08:30:54.602+0000][0.148s][LAPTOP-D73GD8TE][6480][4388][info][gc,cpu       ] GC(0) User=0.00s Sys=0.00s Real=0.00s
[2020-04-02T16:30:54.602+0800][2020-04-02T08:30:54.602+0000][0.148s][LAPTOP-D73GD8TE][6480][4388][info][gc,start     ] GC(1) Pause Full (System.gc())
[2020-04-02T16:30:54.602+0800][2020-04-02T08:30:54.602+0000][0.148s][LAPTOP-D73GD8TE][6480][4388][info][gc,phases,start] GC(1) Marking Phase
[2020-04-02T16:30:54.604+0800][2020-04-02T08:30:54.604+0000][0.149s][LAPTOP-D73GD8TE][6480][4388][info][gc,phases      ] GC(1) Marking Phase 1.591ms
[2020-04-02T16:30:54.604+0800][2020-04-02T08:30:54.604+0000][0.150s][LAPTOP-D73GD8TE][6480][4388][info][gc,phases,start] GC(1) Summary Phase
[2020-04-02T16:30:54.604+0800][2020-04-02T08:30:54.604+0000][0.150s][LAPTOP-D73GD8TE][6480][4388][info][gc,phases      ] GC(1) Summary Phase 0.015ms
[2020-04-02T16:30:54.604+0800][2020-04-02T08:30:54.604+0000][0.150s][LAPTOP-D73GD8TE][6480][4388][info][gc,phases,start] GC(1) Adjust Roots
[2020-04-02T16:30:54.605+0800][2020-04-02T08:30:54.605+0000][0.150s][LAPTOP-D73GD8TE][6480][4388][info][gc,phases      ] GC(1) Adjust Roots 0.652ms
[2020-04-02T16:30:54.605+0800][2020-04-02T08:30:54.605+0000][0.150s][LAPTOP-D73GD8TE][6480][4388][info][gc,phases,start] GC(1) Compaction Phase
[2020-04-02T16:30:54.607+0800][2020-04-02T08:30:54.607+0000][0.153s][LAPTOP-D73GD8TE][6480][4388][info][gc,phases      ] GC(1) Compaction Phase 2.365ms
[2020-04-02T16:30:54.607+0800][2020-04-02T08:30:54.607+0000][0.153s][LAPTOP-D73GD8TE][6480][4388][info][gc,phases,start] GC(1) Post Compact
[2020-04-02T16:30:54.607+0800][2020-04-02T08:30:54.607+0000][0.153s][LAPTOP-D73GD8TE][6480][4388][info][gc,phases      ] GC(1) Post Compact 0.048ms
[2020-04-02T16:30:54.607+0800][2020-04-02T08:30:54.607+0000][0.153s][LAPTOP-D73GD8TE][6480][4388][info][gc,heap        ] GC(1) PSYoungGen: 968K(38400K)->0K(38400K) Eden: 0K(33280K)->0K(33280K) From: 968K(5120K)->0K(5120K)
[2020-04-02T16:30:54.607+0800][2020-04-02T08:30:54.607+0000][0.153s][LAPTOP-D73GD8TE][6480][4388][info][gc,heap        ] GC(1) ParOldGen: 8K(87552K)->925K(87552K)
[2020-04-02T16:30:54.607+0800][2020-04-02T08:30:54.607+0000][0.153s][LAPTOP-D73GD8TE][6480][4388][info][gc,metaspace   ] GC(1) Metaspace: 624K(4864K)->624K(4864K) NonClass: 566K(4352K)->566K(4352K) Class: 58K(512K)->58K(512K)
[2020-04-02T16:30:54.607+0800][2020-04-02T08:30:54.607+0000][0.153s][LAPTOP-D73GD8TE][6480][4388][info][gc             ] GC(1) Pause Full (System.gc()) 0M->0M(123M) 4.869ms
[2020-04-02T16:30:54.607+0800][2020-04-02T08:30:54.607+0000][0.153s][LAPTOP-D73GD8TE][6480][4388][info][gc,cpu         ] GC(1) User=0.00s Sys=0.00s Real=0.01s
[2020-04-02T16:30:54.608+0800][2020-04-02T08:30:54.608+0000][0.153s][LAPTOP-D73GD8TE][6480][1664][info][gc,heap,exit   ] Heap
[2020-04-02T16:30:54.608+0800][2020-04-02T08:30:54.608+0000][0.154s][LAPTOP-D73GD8TE][6480][1664][info][gc,heap,exit   ]  PSYoungGen      total 38400K, used 1664K [0x00000000d5f00000, 0x00000000d8980000, 0x0000000100000000)
[2020-04-02T16:30:54.608+0800][2020-04-02T08:30:54.608+0000][0.154s][LAPTOP-D73GD8TE][6480][1664][info][gc,heap,exit   ]   eden space 33280K, 5% used [0x00000000d5f00000,0x00000000d60a01e8,0x00000000d7f80000)
[2020-04-02T16:30:54.608+0800][2020-04-02T08:30:54.608+0000][0.154s][LAPTOP-D73GD8TE][6480][1664][info][gc,heap,exit   ]   from space 5120K, 0% used [0x00000000d7f80000,0x00000000d7f80000,0x00000000d8480000)
[2020-04-02T16:30:54.608+0800][2020-04-02T08:30:54.608+0000][0.154s][LAPTOP-D73GD8TE][6480][1664][info][gc,heap,exit   ]   to   space 5120K, 0% used [0x00000000d8480000,0x00000000d8480000,0x00000000d8980000)
[2020-04-02T16:30:54.608+0800][2020-04-02T08:30:54.608+0000][0.154s][LAPTOP-D73GD8TE][6480][1664][info][gc,heap,exit   ]  ParOldGen       total 87552K, used 925K [0x0000000081c00000, 0x0000000087180000, 0x00000000d5f00000)
[2020-04-02T16:30:54.608+0800][2020-04-02T08:30:54.608+0000][0.154s][LAPTOP-D73GD8TE][6480][1664][info][gc,heap,exit   ]   object space 87552K, 1% used [0x0000000081c00000,0x0000000081ce76d0,0x0000000087180000)
[2020-04-02T16:30:54.608+0800][2020-04-02T08:30:54.608+0000][0.154s][LAPTOP-D73GD8TE][6480][1664][info][gc,heap,exit   ]  Metaspace       used 627K, capacity 4531K, committed 4864K, reserved 1056768K
[2020-04-02T16:30:54.608+0800][2020-04-02T08:30:54.608+0000][0.154s][LAPTOP-D73GD8TE][6480][1664][info][gc,heap,exit   ]   class space    used 58K, capacity 402K, committed 512K, reserved 1048576K

 

 

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Web服务器三剑客运维配置实战 Nginx+JVM+Tomcat+HTTP协议 视频教程+笔记+课件+资料 虽然在课程中还讲解了部分HTTP协议的技术,但是课程的重点还是NGINX、JVM、Tomcat三相运维与配置技术。课程内容包括了Nginx进阶基础,Nginx配置提升,JVM虚拟机尝试,JVM运维实用排障工具,JVM监控工具,Tomcat配置,Tomcat运维与部署等Web服务器的必备运维部署技术。 ===============课程目录=============== (1)\笔记+课件+资料;目录中文件数:0个 (2)\视频教程;目录中文件数:49个 ├─1.01 HTTP协议-工作原理及消息结构.mp4 ├─1.02 HTTP协议-客户端请求信息及服务端响应信息.mp4 ├─1.03 HTTP协议-请求方法及响应头信息.mp4 ├─1.04 HTTP协议-状态码.mp4 ├─1.05 Nginx进阶基础-Nginx介绍及为什么选择Nginx.mp4 ├─1.06 Nginx进阶基础-IO多路复用及内部技术架构.mp4 ├─1.07 Nginx进阶基础-虚拟主机.mp4 ├─1.08 Nginx进阶基础-虚拟主机.mp4 ├─2.01 Nginx进阶常见配置-虚拟主机+PHP-FPM.mp4 ├─2.02 Nginx进阶-常见配置-反向代理.mp4 ├─2.03 Nginx进阶基础-常见配置-反向代理.mp4 ├─2.04 Nginx进阶基础-upstream.mp4 ├─2.05 Nginx进阶基础-常用配置-会话保持.mp4 ├─2.06 Nginx进阶基础常见配置-动静分离.mp4 ├─2.07 Nginx进阶常见配置-rewrite-概念介绍.mp4 ├─2.08 Nginx进阶常见配置-rewrite实例.mp4 ├─2.09 Nginx进阶常见配置-rewrite实例.mp4 ├─2.10 Nginx进阶常见配置-if指令.mp4 ├─2.11 Nginx进阶常见配置-set及return指令.mp4 ├─2.12 Nginx进阶基础-常见配置-return及break指令.mp4 ├─2.13 Nginx进阶基础-常见配置-location.mp4 ├─3.01 Nginx进阶配置提升-预定义变量及日志详解.mp4 ├─3.02 Nginx进阶配置提升-日志切割及升级.mp4 ├─3.03 Nginx进阶-配置提升-Nginx错误页面.mp4 ├─3.04 Nginx进阶-配置提升-访问控制.mp4 ├─3.05 Nginx进阶-配置提升-流量控制.mp4 ├─3.06 Nginx进阶-提升配置-流量控制.mp4 ├─3.07 Nginx进阶-配置提升-Nginx监控.mp4 ├─3.08 Nginx进阶-配置提升-NginxAlias虚拟目录.mp4 ├─4.01 jvm虚拟机常识-什么是java虚拟机-java如何做到跨平台.mp4 ├─4.02 jvm虚拟机常识-虚拟机结构.mp4 ├─4.03 jvm虚拟机常识-虚拟机堆内存结构.mp4 ├─4.04 jvm虚拟机常识-jvm虚拟机参数类型-常用的jvm参数.mp4 ├─4.05 java细腻及讲解-jvm虚拟机常识-常用垃圾回收算法.mp4 ├─4.06 jvm运维实用排障工具.mp4 ├─4.07 jvm运维实用排障工具-jps-jstack.mp4 ├─4.08 jvm运维实用排障工具-jinfo-jstat.mp4 ├─4.09 jvm运维实用监控工具-virtualvm安装-安装插件.mp4 ├─4.10 jvm运维实用监控工具-如何监控jvm.mp4 ├─5.01 tomcat简介与tomcat基础JDk.mp4 ├─5.02 tomcat&jdk安装.mp4 ├─5.03 tomcat目录介绍-tomcat运维-启动与关闭.mp4 ├─5.04 tomcat运维-tomcat日志说明-tomcat管理功能.mp4 ├─5.05 tomcat运维-server.xml配置文件注释.mp4 ├─5.06 tomcat运维-web站点部署.mp4 ├─5.07 tomcat运维-部署开源站点.mp4 ├─5.08 tomcat运维-tomcat优化.mp4 ├─5.09 tomcat运维-tomcat性能优化.mp4 ├─5.10 tomcat部署war包实战.mp4 (3)\笔记+课件+资料\第1天;目录中文件数:4个 ├─01-第1天-HTTP协议.pdf ├─02-第1天-Nginx进阶基础.pdf ├─第1天-HTTP协议.md ├─第1天-Nginx进阶基础.md (4)\笔记+课件+资料\第2天;目录中文件数:1个
这本书的内容是帮你全面了解java虚拟机,本书第1版两年内印刷近10次,98%以上的评论全部为5星级的好评,是整个Java图书领域公认的经典著作和超级畅销书,繁体版在台湾也十分受欢迎。第2版在第1版的基础上做了很大的改进:根据最新的JDK1.7对全书内容进行了全面的升级和补充;增加了大量处理各种常见JVM问题的技巧和最佳实践;增加了若干与生产环境相结合的实战案例;对第1版中的错误和不足之处的修正;等等。 第2版不仅技术更新、内容更丰富,而且实战性更强。全书共分为五大部分,围绕内存管理、执行子系统、程序编译与优化、高效并发等核心主题对JVM进行了全面而深入的分析,深刻揭示了JVM的工作原理。第一部分从宏观的角度介绍了整个Java技术体系、Java和JVM的发展历程、模块化,以及JDK的编译,这对理解本书后面内容有重要帮助。第二部分讲解了JVM的自动内存管理,包括虚拟机内存区域的划分原理以及各种内存溢出异常产生的原因;常见的垃圾收集算法以及垃圾收集器的特点和工作原理;常见虚拟机监控与故障处理工具的原理和使用方法。第三部分分析了虚拟机的执行子系统,包括类文件结构、虚拟机类加载机制、虚拟机字节码执行引擎。第四部分讲解了程序的编译与代码的优化,阐述了泛型、自动装箱拆箱、条件编译等语法糖的原理;讲解了虚拟机的热点探测方法、HotSpot的即时编译器、编译触发条件,以及如何从虚拟机外部观察和分析JIT编译的数据和结果;第五部分探讨了Java实现高效并发的原理,包括JVM内存模型的结构和操作;原子性、可见性和有序性在Java内存模型中的体现;先行发生原则的规则和使用;线程在Java语言中的实现原理;虚拟机实现高效并发所做的一系列锁优化措施。 前言 第一部分 走近Java 第1章 走近Java 1.1 概述 1.2 Java技术体系 1.3 Java发展史 1.4 Java虚拟机发展史 1.4.1 Sun Classic Exact VM 1.4.2 Sun HotSpot VM 1.4.3 Sun Mobile-Embedded VM Meta-Circular VM 1.4.4 BEA JRockit IBM J9 VM 1.4.5 Azul VM BEA Liquid VM 1.4.6 Apache Harmony Google Android Dalvik VM 1.4.7 Microsoft JVM及其他 1.5 展望Java技术的未来 1.5.1 模块化 1.5.2 混合语言 1.5.3 多核并行 1.5.4 进一步丰富语法 1.5.5 64位虚拟机 1.6 实战:自己编译JDK 1.6.1 获取JDK源码 1.6.2 系统需求 1.6.3 构建编译环境 1.6.4 进行编译 1.6.5 在IDE工具中进行源码调试 1.7 本章小结 第二部分 自动内存管理机制 第2章 Java内存区域与内存溢出异常 2.1 概述 2.2 运行时数据区域 2.2.1 程序计数器 2.2.2 Java虚拟机栈 2.2.3 本地方法栈 2.2.4 Java堆 2.2.5 方法区 2.2.6 运行时常量池 2.2.7 直接内存 2.3 HotSpot虚拟机对象探秘 2.3.1 对象的创建 2.3.2 对象的内存布局 2.3.3 对象的访问定位 2.4 实战:OutOfMemoryError异常 2.4.1 Java堆溢出 2.4.2 虚拟机栈和本地方法栈溢出 2.4.3 方法区和运行时常量池溢出 2.4.4 本机直接内存溢出 2.5 本章小结 第3章 垃圾收集器与内存分配策略 3.1 概述 3.2 对象已死吗 3.2.1 引用计数算法 3.2.2 可达性分析算法 3.2.3 再谈引用 3.2.4 生存还是死亡 3.2.5 回收方法区 3.3 垃圾收集算法 3.3.1 标记-清除算法 3.3.2 复制算法 3.3.3 标记-整理算法 3.3.4 分代收集算法 3.4 HotSpot的算法实现 3.4.1 枚举根节点 3.4.2 安全点 3.4.3 安全区域 3.5 垃圾收集器 3.5.1 Serial收集器 3.5.2 ParNew收集器 3.5.3 Parallel Scavenge收集器 3.5.4 Serial Old收集器 3.5.5 Parallel Old收集器 3.5.6 CMS收集器 3.5.7 G1收集器 3.5.8 理解GC日志 3.5.9 垃圾收集器参数总结 3.6 内存分配与回收策略 3.6.1 对象优先在Eden分配 3.6.2 大对象直接进入老年代 3.6.3 长期存活的对象将进入老年代 3.6.4 动态对象年龄判定 3.6.5 空间分配担保 3.7 本章小结 第4章 虚拟机性能监控与故障处理工具 4.1 概述 4.2 JDK的命令行工具 4.2.1 jps:虚拟机进程状况工具 4.2.2 jstat:虚拟机统计信息监视工具 4.2.3 jinfo:Java配置信息工具 4.2.4 jmap:Java内存映像工具 4.2.5 jhat:虚拟机堆转储快照分析工具 4.2.6 jstack:Java堆栈跟踪工具 4.2.7 HSDIS:JIT生成代码反汇编 4.3 JDK的可视化工具 4.3.1 JConsole:Java监视与管理控制台 4.3.2 VisualVM:多合一故障处理工具 4.4 本章小结 第5章 调优案例分析与实战 5.1 概述 5.2 案例分析 5.2.1 高性能硬件上的程序部署策略 5.2.2 集群间同步导致的内存溢出 5.2.3 堆外内存导致的溢出错误 5.2.4 外部命令导致系统缓慢 5.2.5 服务器JVM进程崩溃 5.2.6 不恰当数据结构导致内存占用过大 5.2.7 由Windows虚拟内存导致的长时间停顿 5.3 实战:Eclipse运行速度调优 5.3.1 调优前的程序运行状态 5.3.2 升级JDK 1.6的性能变化及兼容问题 5.3.3 编译时间和类加载时间的优化 5.3.4 调整内存设置控制垃圾收集频率 5.3.5 选择收集器降低延迟 5.4 本章小结 第三部分 虚拟机执行子系统 第6章 类文件结构 6.1 概述 6.2 无关性的基石 6.3 Class类文件的结构 6.3.1 魔数与Class文件的版本 6.3.2 常量池 6.3.3 访问标志 6.3.4 类索引、父类索引与接口索引集合 6.3.5 字段表集合 6.3.6 方法表集合 6.3.7 属性表集合 6.4 字节码指令简介 6.4.1 字节码与数据类型 6.4.2 加载和存储指令 6.4.3 运算指令 6.4.4 类型转换指令 6.4.5 对象创建与访问指令 6.4.6 操作数栈管理指令 6.4.7 控制转移指令 6.4.8 方法调用和返回指令 6.4.9 异常处理指令 6.4.10 同步指令 6.5 公有设计和私有实现 6.6 Class文件结构的发展 6.7 本章小结 第7章 虚拟机类加载机制 7.1 概述 7.2 类加载的时机 7.3 类加载的过程 7.3.1 加载 7.3.2 验证 7.3.3 准备 7.3.4 解析 7.3.5 初始化 7.4 类加载器 7.4.1 类与类加载器 7.4.2 双亲委派模型 7.4.3 破坏双亲委派模型 7.5 本章小结 第8章 虚拟机字节码执行引擎 8.1 概述 8.2 运行时栈帧结构 8.2.1 局部变量表 8.2.2 操作数栈 8.2.3 动态连接 8.2.4 方法返回地址 8.2.5 附加信息 8.3 方法调用 8.3.1 解析 8.3.2 分派 8.3.3 动态类型语言支持 8.4 基于栈的字节码解释执行引擎 8.4.1 解释执行 8.4.2 基于栈的指令集与基于寄存器的指令集 8.4.3 基于栈的解释器执行过程 8.5 本章小结 第9章 类加载及执行子系统的案例与实战 9.1 概述 9.2 案例分析 9.2.1 Tomcat:正统的类加载器架构 9.2.2 OSGi:灵活的类加载器架构 9.2.3 字节码生成技术与动态代理的实现 9.2.4 Retrotranslator:跨越JDK版本 9.3 实战:自己动手实现远程执行功能 9.3.1 目标 9.3.2 思路 9.3.3 实现 9.3.4 验证 9.4 本章小结 第四部分 程序编译与代码优化 第10章 早期(编译期)优化 10.1 概述 10.2 Javac编译器 10.2.1 Javac的源码与调试 10.2.2 解析与填充符号表 10.2.3 注解处理器 10.2.4 语义分析与字节码生成 10.3 Java语法糖的味道 10.3.1 泛型与类型擦除 10.3.2 自动装箱、拆箱与遍历循环 10.3.3 条件编译 10.4 实战:插入式注解处理器 10.4.1 实战目标 10.4.2 代码实现 10.4.3 运行与测试 10.4.4 其他应用案例 10.5 本章小结 第11章 晚期(运行期)优化 11.1 概述 11.2 HotSpot虚拟机内的即时编译器 11.2.1 解释器与编译器 11.2.2 编译对象与触发条件 11.2.3 编译过程 11.2.4 查看及分析即时编译结果 11.3 编译优化技术 11.3.1 优化技术概览 11.3.2 公共子表达式消除 11.3.3 数组边界检查消除 11.3.4 方法内联 11.3.5 逃逸分析 11.4 Java与CC++的编译器对比 11.5 本章小结 第五部分 高效并发 第12章 Java内存模型与线程 12.1 概述 12.2 硬件的效率与一致性 12.3 Java内存模型 12.3.1 主内存与工作内存 12.3.2 内存间交互操作 12.3.3 对于volatile型变量的特殊规则 12.3.4 对于long和double型变量的特殊规则 12.3.5 原子性、可见性与有序性 12.3.6 先行发生原则 12.4 Java与线程 12.4.1 线程的实现 12.4.2 Java线程调度 12.4.3 状态转换 12.5 本章小结 第13章 线程安全与锁优化 13.1 概述 13.2 线程安全 13.2.1 Java语言中的线程安全 13.2.2 线程安全的实现方法 13.3 锁优化 13.3.1 自旋锁与自适应自旋 13.3.2 锁消除 13.3.3 锁粗化 13.3.4 轻量级锁 13.3.5 偏向锁 13.4 本章小结 附  录 附录A 编译Windows版的OpenJDK 附录B 虚拟机字节码指令表 附录C HotSpot虚拟机主要参数表 附录D 对象查询语言(OQL)简介 附录E JDK历史版本轨迹

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值