22Java内存区域-简介
23Java内存区域-程序计数器
24Java内存区域-Java虚拟机栈
25Java内存区域-本地方法栈
本地方法栈和 java 栈非常类似,最大的不同在于 java 栈用于方法的调用,而本地方法 栈则用于本地方法的调用,作为对 java 虚拟机的重要扩展,java 虚拟机允许 java 直接调用 本地方法(通常使用 C 编写)
26Java内存区域-堆内存
java 堆在虚拟机启动的时候建立,它是 java 程序最主要的内存工作区域。几乎所有的 java 对象实例都存放在 java 堆中。堆空间是所有线程共享的,这是一块与 java 应用密切相关的内存空间。
27Java内存区域-方法区
28Java内存区域-直接内存和运行时常量池
java 的 NIO 库允许 java 程序使用直接内存。直接内存是在 java 堆外的、直接向系统申 请的内存空间。通常访问直接内存的速度会优于 java 堆。因此出于性能的考虑,读写频繁 的场合可能会考虑使用直接内存。由于直接内存在 java 堆外,因此它的大小不会直接受限 于 Xmx 指定的最大堆大小,但是系统内存是有限的,java 堆和直接内存的总和依然受限于 操作系统能给出的最大内存。
第29节对象在内存中的布局-对象的创建00:21:19分钟
第30节探究对象的结构00:13:47分钟
第31节深入理解对象的访问定位00:08:01分钟
第32节垃圾回收-概述00:06:20分钟
第33节垃圾回收-判断对象是否存活算法-引用计数法详解00:14:08分钟
第34节垃圾回收-判断对象是否存活算法-可达性分析法详解00:07:09分钟
第35节垃圾回收算法-标记清除算法00:04:36分钟
第36节垃圾回收算法-复制算法00:14:35分钟
第37节垃圾回收算法-标记整理算法和分代收集算法00:05:24分钟
第38节垃圾收集器-serial收集器详解00:09:45分钟
第39节垃圾收集器-parnew收集器详解00:04:53分钟
第40节垃圾收集器-parallel收集器详解00:11:02分钟
第41节垃圾收集器-cms收集器详解00:14:58分钟
第42节最牛的垃圾收集器-g1收集器详解00:18:04分钟
第43节内存分配-概述00:04:23分钟
第44节内存分配-Eden区域00:22:51分钟
第45节内存分配-大对象直接进老年代00:06:42分钟
第46节内存分配-长期存活的对象进入老年代00:03:40分钟
第47节内存分配-空间分配担保00:04:54分钟
第48节内存分配-逃逸分析与栈上分配00:10:32分钟
逃逸分析(个人理解):就是方法内的对象,可以被方法外所访问。
方法逃逸的方式如下:
public class EscapeTest {
public static Object obj;
public void globalVariableEscape() {
// 给全局变量赋值,发生逃逸
obj = new Object(); }
public Object methodEscape() {
// 方法返回值,发生逃逸
return new Object(); }
public void instanceEscape() {
// 实例引用发生逃逸 test(this); }
}
栈上分配:就是把没发生逃逸的对象,在栈分配空间。(一般对象分配空间是在堆)逃逸
二者联系:jvm根据对象是否发生逃逸,会分配到不同(堆或栈)的存储空间。
如果对象发生逃逸,那会分配到堆中。(因为对象发生了逃逸,就代表这个对象可以被外部访问,换句话说,就是可以共享,能共享数据的,无非就是堆或方法区,这里就是堆。)
如果对象没发生逃逸,那会分配到栈中。(因为对象没发生逃逸,那就代表这个对象不能被外部访问,换句话说,就是不可共享,这里就是栈。)
那我们再想深一层,为什么会有逃逸分析,有栈上分配这些东西?
当然是为了主体的考虑,主体就是jvm,或者直接说为了GC考虑也不为过。大家想想,GC主要回收的对象是堆和方法区。GC不会对栈、程序计数器这些进行回收的,因为没东西可以回收。
说回来,如果方法逃逸,那么对象就会分配在堆中,这个时候,GC就要工作了。如果没发生方法逃逸,那么对象就分配在栈中,当方法结束后,资源就自动释放了,GC压根不用操心。所以哈,方法逃逸这东西,主要也是为GC打工的,或者说为GC服务吧!说到这里,可能有人会问,那方法逃逸和性能还是没关系哈?emmm!!!其实有,想深一层,GC不运行的时候,程序的性能肯定会好点,不会占用程序运行的时间。虽然GC清扫垃圾的速度很快,但是当一个程序足够大的时候,对象就自然多了,垃圾也自然多了,这个时候GC就忙了。
巴拉巴拉这么多,主要就是想说:能在方法内创建对象,就不要再方法外创建对象。毕竟这是为了GC好,也是为了提高性能。
第49节虚拟机工具介绍00:10:27分钟
第50节虚拟机工具-jps详解00:11:20分钟
第51节虚拟机工具-jstat详解00:09:20分钟
第52节虚拟机工具-jinfo详解00:05:03分钟
第53节虚拟机工具-jmap详解00:08:48分钟
第54节虚拟机工具-jhat详解00:08:10分钟
第55节虚拟机工具-jstack详解00:10:19分钟
第56节可视化虚拟机工具-Jconsole内存监控00:07:09分钟
第57节可视化虚拟机工具-Jconsole线程监控00:12:18分钟
第58节死锁原理以及可视化虚拟机工具-Jconsole线程死锁监控00:10:38分钟
第59节VisualVM使用详解00:08:03分钟
第60节性能调优概述00:11:22分钟
第61节性能调优-案例100:23:28分钟
第62节性能调优-案例200:10:05分钟
第63节性能调优-案例300:12:41分钟
第64节前半部分内容整体回顾00:15:41分钟
第65节Class文件简介和发展历史 00:11:26分钟
第66节Class文件结构概述 00:16:50分钟
第67节Class文件设计理念以及意义 00:13:41分钟
第68节文件结构-魔数 00:09:49分钟
第69节文件结构-常量池 00:23:44分钟
第70节文件结构-访问标志 00:11:36分钟
第71节文件结构-类索引00:11:26分钟
第72节文件结构-字段表集合00:13:21分钟
第73节文件结构-方法表集合00:10:06分钟
第74节文件结构-属性表集合00:18:23分钟
第75节字节码指令简介00:09:18分钟
第76节字节码与数据类型00:09:34分钟
第77节加载指令00:09:33分钟
第78节运算指令00:10:24分钟
第79节类型转换指令00:13:42分钟
第80节对象创建与访问指令00:09:38分钟
第81节操作树栈指令00:03:27分钟
第82节控制转移指令00:11:58分钟
第83节方法调用和返回指令00:06:37分钟
第84节异常处理指令00:09:44分钟
第85节同步指令00:07:34分钟
第86节类加载机制概述00:07:26分钟
第87节类加载时机00:13:15分钟
第88节类加载的过程-加载00:15:15分钟
第89节类加载的过程-验证00:10:24分钟
第90节类加载的过程-准备00:05:40分钟
第91节类加载的过程-解析00:14:04分钟
第92节类加载的过程-初始化00:19:41分钟
第93节类加载器00:22:41分钟
第94节双亲委派模型00:17:03分钟
第95节运行时栈帧结构00:08:46分钟
第96节局部变量表00:20:48分钟
第97节操作数栈00:08:36分钟
第98节动态连接00:02:56分钟
第99节方法返回地址和附加信息00:03:24分钟
第100节方法调用-解析调用00:09:49分钟
第101节方法调用-静态分派调用00:16:21分钟
第102节方法调用-动态分派调用00:09:02分钟
第103节动态类型语言支持00:09:27分钟
第104节字节码执行引擎小结00:03:38分钟
第105节总结与回顾00:10:55分钟
第106节happens-before简单概述00:15:17分钟
第107节重排序问题00:23:19分钟
第108节锁的内存语义00:13:54分钟
第109节volatile的内存语义00:12:04分钟
第110节final域内存语义00:34:07分钟