定义一个 a=1; 然后起三个线程去执行 a=a+1; 那么最终的执行结果会是什么呢?

2021 年 3 月 19 日
 shunfy
4885 次点击
所在节点    程序员
27 条回复
yamasa
2021 年 3 月 19 日
你需要补充多线程和并行的基础知识。答案是 unknown,根据 cpu 调度,1-4 之间全部可能。
Chenamy2017
2021 年 3 月 19 日
这不是操作系统里面并发的基本例子吗,自己跑一下比你问强多了。
nightwitch
2021 年 3 月 19 日
未定义行为
ingin
2021 年 3 月 19 日
@yamasa 我觉得是 2-4 之间
pkwenda
2021 年 3 月 19 日
@ingin #4 you are right
yamasa
2021 年 3 月 19 日
@ingin 对 我脑抽了。
CEBBCAT
2021 年 3 月 19 日
涉及可重入性,单纯地问答案其实没有什么意义
webcoder
2021 年 3 月 19 日
不作线程锁的话,2-4 都有可能。
ch2
2021 年 3 月 19 日

结果为 4 的可能性是最大的,2 和 3 的情况比 segement fault 还要罕见
beat
2021 年 3 月 19 日
做好并发控制,答案就是 4
gdt
2021 年 3 月 19 日
随机的
xuanbg
2021 年 3 月 19 日
等待足够的时间,a 就是 4 。
hauibojek
2021 年 3 月 19 日
都执行完不是 4 吗。
cxe2v
2021 年 3 月 19 日
a=a+1 够复杂耗时的话,结果应该就会有明显差异了
hejw19970413
2021 年 3 月 19 日
这个 都有可能。
nullllllllllllll
2021 年 3 月 19 日
首先我们排除掉 0[狗头]
norz
2021 年 3 月 19 日
@nullllllllllllll 再排除掉 1[狗头]
faceRollingKB
2021 年 3 月 19 日
读 1 、写 1 、读 2 、写 2 、读 3 、写 3

除了读 n 位于写 n 之前外其他操作随机排列组合,就可以得出所有可能的结果
realpg
2021 年 3 月 19 日
现代计算机,没特殊情况,99%可能是 4

当然你要起十万个线程就不可能正好
mingl0280
2021 年 3 月 19 日
那要看你用的是 atomic 还是非 atomic 的,算法有没有加锁等等情况,atomic/正确加锁的就是 4,其他的随机 2-4 都有可能。

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/763156

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX