「CPU、内存、磁盘之间的速度差异」
CPU 把要处理的数据加载到自己的缓存中,处理完了放回自己的缓存。
另一个 CPU 同样的处理,就导致可能看不到上一个 CPU 处理的结果。
程序中的一行代码往往不是一条 CPU 指令。
线程切换的时候,可能会在一个代码执行的中间地方切换。
优化会为了更高效的利用 CPU 缓存,将代码指令重排。
这个重排的过程会导致看似没问题的代码,多线程出现逻辑问题。
接下来的几篇文章会介绍如何解决上面提到的「可见性、原子性、有序性」的问题。
上一篇:CentOS7.9集群部署(配置hosts、集群免密、时间同步)
下一篇:xss-labs/level-2