Java 并发编程实战-01-分布图

为了合理利用 CPU 的高性能,平衡这三者的速度差异,计算机体系结构、操作系统、编译程序都做出了贡献,主要体现为:

1. CPU 增加了缓存,以均衡与内存的速度差异;

2. 操作系统增加了进程、线程,以分时复用 CPU,进而均衡 CPU 与 I/O 设备的速度差异;

3. 编译程序优化指令执行次序,使得缓存能够得到更加合理地利用。

样例:

instance = new Singleton();

我们以为的 new 操作应该是:

        分配一块内存 M;

        在内存 M 上初始化 Singleton 对象;

        然后 M 的地址赋值给 instance 变量。

但是实际上优化后的执行路径却是这样的:

        分配一块内存 M;

        将 M 的地址赋值给 instance 变量;

        最后在内存 M 上初始化 Singleton 对象。

多线程切换将出现问题;

使用 volatile 结局。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值