上图灰色部分不存在垃圾回收,所谓jvm调优是针对左边黄色部分,95%的情况下调的是heap(堆)
类加载器ClassLoader 类加载器的分类如下 运行demo如下 加载原理 类加载器要加载一个类,它首先检查此类是否已被加载,然后再委托双亲加载器加载此类,它的双亲加载器再委托它的双亲,这样一直委托到启动加载器,启动加载 器在从核心API查找此类,如果有就返回此类,否则就他的子加载器就查找此类,如果都没有就抛出 为何采用双亲委派机制 能不能自己写个类叫java.lang.System? 解释:为了不让我们写System类,类加载采用委托机制,这样可以保证爸爸们优先,爸爸们能找到的类,儿子就没有机会加载。而System类是Bootstrap加载器加载的,就算自己重写,也总是使用Java系统提供的System,自己写的System类根本没有机会得到加载。 但是,我们可以自己定义一个类加载器来达到这个目的,为了避免双亲委托机制,这个类加载器也必须是特殊的。由于系统自带的三个类加载器都加载特定目录下的类,如果我们自己的类加载器加载一个特殊的目录,那么系统的加载器就无法加载,也就是最终还是由我们自己的加载器加载
本地方法接口(JNI)/本地方法栈(Native Method Stack) 本地接口 本地方法栈
PC计数器
方法区
栈 栈帧中存储3类数据 栈运行原理 栈+堆+方法区的交互关系
堆 java7之前的内存模型如下
堆内存调优 java7 java8
利用jdk自带查看jvm工具使用:jvisualvm 图形化界面即可; 分析字节码使用javap 命令即可,javap -c xxx.class>xxx.txt