如何解决切换到另一个核心后,同一个线程会看到最新值吗?
如果进程只包含 1 个线程。并且在代码中我们定义了一个变量 int x = 10
,它没有被 volatile
限定。
- 首先,线程在 cpu core1 上运行,它读取
x
并将其更改为5
; - 然后,线程休眠并重新调度到另一个 cpu core2 上;
- 然后,线程尝试从内存中读取
x
;
我有几个问题:
-
Q1:cpu包含存储缓冲区,线程task_struct包含寄存器值,所以即使存储缓冲区没有刷新到缓存,线程仍然会通过恢复任务上下文读取最新值?
-
Q2:如果 cpu 寄存器在将 x 更改为
5
后被其他指令重用,则最新值5
现在不会存储在寄存器中。现在切换发生了,线程现在在另一个 core2 上运行,线程会读取最新值吗?因为存储缓冲区没有被刷新,所以 cpu core2 不会看到缓存行失效,我认为线程会从内存中读取,所以读取值是10
?或者操作系统应用了一些障碍来在上下文切换之前刷新整个存储缓冲区并在读取之前使无效队列无效?
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。