并发编程 - 可见性,原子性和有序性问题

并发带来的问题

一、并发的根源

cpu、内存、I/O设备 三者的速度差异

二、并发带来的问题

2.1 缓存导致的可见性

可见性:一个线程对共享变量的修改,另一个线程可以立马看到,称为“可见性”(你的修改我能看见)。在这里插入图片描述

2.2 线程切换带来的原子性问题

把一个或者多个操作在cpu执行过程中不被中断的特性称为“原子性”(原子哦,不可切割)。

非原子性操作:
在这里插入图片描述

2.3 编译优化带来的有序性问题

编译器为了优化性能,可能会调整指令顺序哦。

public class Singleton {
  static Singleton instance;
  static Singleton getInstance(){
    if (instance == null) {
      synchronized(Singleton.class) {
        if (instance == null)
          instance = new Singleton();
        }
    }
    return instance;
  }
}

因重排序带来的异常执行
在这里插入图片描述

三、总结

并发固然高效,但带来的问题也需要重视哦。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值