• 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标记的变量可以被编译器优化
  • 相关阅读:
    C# NPOI 导入与导出Excel文档 兼容xlsx, xls(xf13中已经引用了xlsx的npoi)
    ASP.Net超时时间已到解决办法-
    解决SqlDataSource连接超时的问题
    SqlDataSource控件超时的困惑
    Redis+Keepalived
    Linux Ubuntu 16.04 安装步骤+远程环境
    JDK 安装
    Maven 安装
    CAT 默认密码修改
    CAT 监控搭建
  • 原文地址:https://www.cnblogs.com/flymili1017/p/13490018.html
Copyright © 2020-2023  润新知