1.
两个线程并发执行以下代码,假设a是全局变量,那么以下输出______是不可能的?
void foo(){
++a;
printf("%d ",a);
}
A、3 2 B、2 3 C、3 3 D、2 2
我想知道D为什么可能出现,个人觉得 AD都不可能呀
不好意思漏了条件了 a初始为1
我怎么觉得都可能呢?
假设线程x和y同时执行,x和y可随时被抢占,a的初始值为1
A:3, 2
y先执行++a,a为2;
y再执行printf,a入栈,在打印到终端之前切换到x
x执行++a,a为3;
x执行printf,输出3;再切换到y
y执行打印,输出2
B:2 3
x先执行++a,a为2;
x再执行printf,输出2;切换到y
y执行++a,a为3;
y执行printf,输出3;
C:3 3
x先执行++a,a为2;切换到y
y执行++a,a为3;
y执行printf,输出3;切换到x
x执行printf,输出3
D:2 2
类似C,a的初始值为0即可
这里关键有两点:
(1)两个线程可随时被抢占
(2)++a和printf不是原子指令,可随时被打断
;特别注意函数printf,a作为参数压栈后,a再变化则不会影响输出(printf实际打印的是压栈的参数,是值拷贝的栈变量)
ljf10000所说的有些问题,首先printf是原子操作,不会被打断。
答案选A。
两个线程顺序执行,没有并发,B出现。
两个线程先把++a操作执行过后,再执行printf函数,c出现。
选项D是假设线程A先执行++a操作但没有写回到内存,这时线程B执行++a操作写回 内存并printf,输出2_,线程A继续执行,++a操作写回内存,a的值保持2,再printf
2_,所以结果为2_2_;