线程1: i++; i++; 线程2: i+=2; 的问题 (2013年某公司笔试题目)

       题目:

全局的int i = 0;

线程1: i++; i++; 

线程2: i+=2; 


     问: 最后i的取值可能是()

a. 1    b. 2.    c   3     d  4


       首先我们就可以断定, a肯定不对, 无论线程怎么走, 总会执行 i+=2, 怎么可能加着加着就成了1呢, 那不是变少了么?


       我们先看程序:

#include 

int main()
{
	int i = 0; 
	i++;

	return 0;
}
      好, 我们来看看汇编代码:

线程1: i++; i++; 线程2: i+=2; 的问题 (2013年某公司笔试题目)_第1张图片


        我们看到, i++其实并不是原子操作, 而是要经历3个步骤, 这三个步骤都是可以被线程打断的。 有的朋友可能不太熟悉汇编, 没关系, 我来解释一下, 上面三个语句的作用分别是:

     1. 把内存i的值放到寄存器eax中;

     2. eax中的值加1

     3. 然后把eax的值又返回到内存i中


       下面, 我们来做做这个题目:

        假设先执行完线程1, 再执行线程2, 那结果必然是4, 这个很简单吧。


        假设先执行线程1的i++; 那么此时i的值就是1了, 然后再执行i+=2,  别忘了, i+=2需要分三个步骤, 假设在执行这三个步骤的过程中被线程1打断(此时, 线程2的eax是3, 但还没有返回给i), 那么线程1会继续执行i++, 执行完后i的值是2,  随后, 线程2的eax中的3返回给i (把线程1产生的2这个值给覆盖掉了),  所以, 随后i的值为3.


        假设线程2先执行, 在执行i+=2的时候, 被线程1打断(此时, i的值是0,  线程2的eax的值是2, 但还没有来得及返回给i), 然后线程1执行i++和i++后, i的值是2, 随后, 线程2的eax中的2返回给i,  所以, i的值为2.


        所以, 该题目选bcd.


         这类题目其实很简单, 多分析一下就可以了, 是必须要拿分的啊。





      

你可能感兴趣的:(S1:,C/C++,s2:,进程线程,S3:,笔试面试)