最小值是 2 情况分析
线程 1 ( 内存 ) 线程 2
i = 0
1. 读取 i = 0
2. 执行 i++ 99 次
4. i = 99 -> 将 i = 99 写回内存 i = 99
5. 执行 i++ 一次, i = 1
6. 将 i=1 写入到内存中
i = 1
7. 读入 i=1 ,执行一次 i++
得到 i = 2
共计 100 次累加操作结束
i = 100
9. 将 i = 100 写回内存中
i = 100
10 将 i=2 写入到内存中 i = 2
线程A 拿了个0,放在手里,等线程B计算到最后一步,写入i,i变成了1。 此时线程B拿到这个1,一直等到线程A计算完,线程B再完成计算,i变成2。 为什么不能更小呢?比如i = 1. 因为必须要两次覆盖才能最小。线程A和线程B一直都在使i变大。i变小的唯一途径就是被另外一个线程覆盖。 所以要想线程A的值变小,线程B必须覆盖一次A,线程B的值要想变小就必须被线程A覆盖一次。 覆盖意味着什么? 覆盖意味着i++,拿到i,i加1,然后写回。 两次覆盖就加两次。所以i最小为2.
如此,假设两个线程的执行步骤如下:
1. 线程A执行第一次i++,取出内存中的i,值为0,存放到寄存器后执行加1,此时CPU1的寄存器中值为1,内存中为0;
2. 线程B执行第一次i++,取出内存中的i,值为0,存放到寄存器后执行加1,此时CPU2的寄存器中值为1,内存中为0;
3. 线程A继续执行完成第99次i++,并把值放回内存,此时CPU1中寄存器的值为99,内存中为99;
4. 线程B继续执行第一次i++,将其值放回内存,此时CPU1中的寄存器值为1,内存中为1;
5. 线程A执行第100次i++,将内存中的值取回CPU2的寄存器,并执行加1,此时CPU2的寄存器中的值为2,内存中为1;
6. 线程B执行完所有操作,并将其放回内存,此时CPU1的寄存器值为100,内存中为100;
7. 线程A执行100次操作的最后一部分,将CPU2中的寄存器值放回内存,内存中值为2;
8. 结束!
所以该题目便可以得出最终结果,最小值为2,最大值为200。