摘要:
运行时数据区的构成 PC 程序计数器 存放指令位置 虚拟机的运行,类似于这样的循环: while( not end ) { 取PC中的位置,找到对应位置的指令; 执行该指令; PC ++; } JVM Stack Frame - 每个方法对应一个栈帧 Local Variable Tab 阅读全文
摘要:
类加载流程 class 是怎么从硬盘中加载到内存中:编译 加载 初始化 Loading 双亲委派,主要出于安全来考虑 package com.mashibing.jvm.c2_classloader; public class T004_ParentAndChild { public static 阅读全文
摘要:
1:JVM基础知识 什么是JVM JAVA VIRTUAL MACHINE 从编码到运行过程 jvm跟class无关。任何语言只要能遵循class的规范,一样能被jvm 运行。 JDK、JRE、JVM的关系 jvm实现 2:ClassFileFormat 整个class文件的格式就是一个二进制字节流 阅读全文
摘要:
JMM 硬件层的并发优化基础知识 硬件层数据一致性 读取缓存以cache line为基本单位,目前64bytes 位于同一缓存行的两个不同数据,被两个不同CPU锁定,产生互相影响的伪共享问题 伪共享问题:JUC/c_028_FalseSharing 使用缓存行的对齐能够提高效率 package co 阅读全文
摘要:
Java并发内存模型 使用JavaAgent测试Object的大小 对象大小(64位机) 观察虚拟机配置 java XX:+PrintCommandLineFlags version 对象的内存布局 在HotSpot虚拟机里,对象在堆内存中的存储布局可以划分为三个部分:对象头(Header)、实例数 阅读全文
摘要:
ThreadLocal ThreadLocal 修饰的变量,是线程独有的 ThreadLocal源码 set方法 获取当前线程,并获取当前线程的ThreadLocalMap实例(从getMap(Thread t)中很容易看出来)。 如果获取到的map实例不为空,调用map.set()方法,否则调用构 阅读全文
摘要:
面试题1 实现一个容器,提供两个方法add、size,写两个线程: 线程1,添加10个元素到容器中 线程2,实时监控元素个数,当个数到5个时,线程2给出提示并结束 wait¬ify /** * 曾经的面试题:(淘宝?) * 实现一个容器,提供两个方法,add,size * 写两个线程,线程1添 阅读全文
摘要:
Atomic Vs Sync Vs LongAdder package com.mashibing.juc.c_018_00_AtomicXXX; import java.util.concurrent.TimeUnit; import java.util.concurrent.atomic.Ato 阅读全文