- JVM内存结构:程序计数器、堆、栈、方法区、直接内存,运行时常量池的区别
程序计数器:是一块较小的内存空间,可以把它看成是当前线程所执行的字节码的行号指示器,字节码解释器就是通过改变计数器的值来选取下一条需要执行的字节码指令。Java虚拟机的多线程是通过线程轮流切换并分配处理器执行时间的方式来实现的,任何时间,一个处理器都只会执行一条线程,因此为了线程切换后能恢复到正确的位置,每个线程都需要一个独立的程序计数器,各条线程之间计数器互补影响,独立存储,所以是“线程私有”的内存。是唯一一个没有规定任何内存泄露的区域
栈:栈分为Java虚拟机栈和本地方法栈,也是线程私有
Java虚拟机栈:存放局部变量表,局部变量表存放了各种基本数据类型,对象引用类型
本地方法栈:Native方法服务
堆:线程共享,存放对象实例
方法区:线程共享,存储虚拟机加载的类信息、常量、静态变量
运行时常量池:存放编译期生成的各种字面量和符号引用
直接内存:JDK1.4中引用NIO类,使用Native函数库直接分配堆外内存,然后通过一个存储在Java堆中的DirectByteBuffer对象作为这块内存的引用进行操作
- Java内存模型:内存可见性、重排序、顺序一致性、volatile、锁、final
https://blog.csdn.net/qq_31997407/article/details/79705767
- 垃圾收集器
参考《深入理解JVM虚拟机》第三章,垃圾收集器与内存分配策略
- JVM参数及调优
https://blog.csdn.net/a_dreaming_fish/article/details/51208527
https://blog.csdn.net/baidu_39299382/article/details/80330311
- Java对象模型:oop-klass,对象头
https://blog.csdn.net/baidu_39299382/article/details/80330399
- HotSpot:即时编译器、编译优化
https://blog.csdn.net/qq_26807245/article/details/80841051
-
类加载机制:classLoader、类加载过程、双亲委派(破坏双亲委派)、模块化(jboss modules、osgi、jigsaw)
https://blog.csdn.net/baidu_39299382/article/details/80330442
-
虚拟机性能监控与故障处理工具:jps, jstack, jmap、jstat, jconsole, jinfo, jhat, javap, btrace、TProfiler
https://blog.csdn.net/baidu_39299382/article/details/80330476
- 编译与反编译 : javac,javap,jad,crf
https://blog.csdn.net/baidu_39299382/article/details/80330538