Avatar notebook default
21篇文章 · 25184字 · 2人关注
  • Resize,w 360,h 240
    final域的内存语义

    1.final域的重排序规则: 1.在构造函数内对一个final域的写入,与随后把这个被构造对象的引用赋值给一个引用变量,这两个操作之间不能重排...

  • Resize,w 360,h 240
    锁的内存语义

    1.锁的释放和获取的内存语义: 当线程获取锁时,JMM会把该线程对应的本地内存置为无效。从而使得被监视器保护的临界区代码必须从主内存中读取共...

  • Resize,w 360,h 240
    volatile的内存语义

    1.volatile的特性 a>可见性:对一个volatile变量的读,总是能看到(任意线程)对这个volatile变量最后的写入 b>原子性:...

  • Resize,w 360,h 240
    JMM之重排序和happens-before

    1.什么是数据依赖性? 如果两个操作访问同一个变量,且有一个是写操作,此时两个操作就存在数据依赖性。 编译器和处理器可能会对操作做重排序,但是在...

  • Resize,w 360,h 240
    JMM基础

    Java线程之间的通信由Java内存模型(JMM)控制,JMM决定一个线程对共享变量的写入何时对另一个线程可见。从抽象角度来看,JMM定义...

  • Resize,w 360,h 240
    Synchronized中锁的变化

    synchronized用的锁是存在Java对线头里的。如果对象是数组类型,则虚拟机用3个字宽(Word 一字宽等于4字节,即32bit)存储对...

  • synchronized的实现原理

    Java虚拟机可以支持方法级的同步和方法内部一段指令序列的同步,这两种同步结构都是使用管程来支持的。 Java中的每一个对象都可以作为锁,具体表...

  • volatile的应用

    volatile是轻量级的synchronized,它在多处理器开发中保证了共享变量的“可见性”,它比synchronized的使用开销低因为,...

  • ReentrantLock类和ReentrantReadWriteLock类的使用

    在Java多线程中,可以使用synchronized关键字来实现线程之间同步互斥,但在JDK1.5中新增加了ReentrantLock类也能达到...

文集作者