参考资料近期有看尚硅谷讲jvm专题的视频,看完之后做个笔记,仅供自用。
进度:不跨级看到P46,然后跳到P52
关键字:jvm内存分区,执行引擎、堆内的分区(Eden,S0,S1,老年区old)、GC类型(young GC和full GC)、年轻代老年代之间的关系?(随着年龄的增加,对象会逐渐挪到老年代,到了老年代之后基本很“稳定”)引发GC的时机,性能优化的目的(减少GC,因为GC线程执行时,用户线程就会被打断,影响效率)、OOM什么时候产生的(老年代满了之后),S0与S1的关系?
垃圾回收器,垃圾回收算法
性能调优的工具
性能调优的指令
制造一个OOM
制造一个StackOverError
字符串常量池和堆的关系?关键是【字符串常量池】在哪???
jvm的参数
-xss 初始栈大小
字符串常量池是在哪的?
jvm基础
一些简单的概念jvm内存分区:
前导知识:
类加载机制(加载:编译成字节码进到内存中,链接:忘了是啥了?,初始化:变量赋值?)
类加载器的类型(引导类加载器 和 自定义类加载器,ext加载器的范围,APP加载器)
双亲委派机制(处理流程,为什么要这样做,安全!)
关于双亲委派的特殊问题(自定义一个java.lang.String类,在里面写个main方法执行会怎样?会找不到main方法,因为根据双亲委派机制,bootstrap加载器将加载lang包下的String类,而真正的String类中是没有main方法的)
bootstrap类加载器是由c或C语言写的,所以当通过String类拿到它的类加载器时是拿不到的,为null……
jdk8的字符串常量池和运行时常量池
程序计数器是一块较小的内存区域,作用可以看做是当前线程执行的字节码的位置指示器。分支、循环、跳转、异常处理和线程恢复等基础功能都需要依赖这个计算器来完成
String 类中的 intern() 方法值得注意的是,运行时产生的新常量也可以被放入常量池中,比如 String 类中的 intern() 方法产生的常量。
intern方法参考



