zoukankan      html  css  js  c++  java
  • JMM内存模型

    MESI缓存一致性协议

     多个cpu从主内存读取同一个数据到各自的高速缓存,当其中的一个CPU修改了缓存里的数据,该数据会马上同步回主内存,其它CPU通过总线嗅探机制可感知到数据的变化从而将自己缓存里的数据失效

    Lock、unLock

    总线加lock变成串行,效率降低、store前加lock实现并行

    1、防止并发操作,多个线程同时往主线写数据

    2、防止store后、还没有写入总线,就已经MESI缓存一致性协议

    并发编程的三大特性:可见性原子性有序性

    volatile保证可见性和有序性,但是不保证原子性,保证原子性需要借助synchronized这样的锁机制

    volatile和synchronized的区别

    • volatile本质是在告诉jvm当前变量在寄存器(工作内存)中的值是不确定的,需要从主存中读取; synchronized则是锁定当前变量,只有当前线程可以访问该变量,其他线程被阻塞住。
    • volatile仅能使用在变量级别;synchronized则可以使用在变量、方法、和类级别的
    • volatile仅能实现变量的修改可见性,不能保证原子性;而synchronized则可以保证变量的修改可见性和原子性
    • volatile不会造成线程的阻塞;synchronized可能会造成线程的阻塞。
    • volatile标记的变量不会被编译器优化;synchronized标记的变量可以被编译器优化
  • 相关阅读:
    不同浏览器的JS如何兼容?
    过滤器如何配置(javax.servlet.Filter)?
    hibernate中 dialect,lazy,inverse,cascade属性的用途?
    json注记
    php: $$str
    MySql计算字段的长度
    封装一个获取变量准确类型的函数
    JavaScript如何创建一个对象
    python+selenium自动登录163邮箱
    获取cookie
  • 原文地址:https://www.cnblogs.com/flymili1017/p/13490018.html
Copyright © 2011-2022 走看看