蔚然成麟er
2017-04-06 23:26
我在EnergySystem类中的将得到的能量值增加到目标能量盒中语句修改了一下:
System.out.println("=======" + (energyBoxes[to] += amount) + "=======");
用来验证当前线程是否把前面的从源能量盒中得到的能量真的加到了目标能量盒中;
部分输出如下:
由上面的结果可以看出,在大部分线程的执行过程中,并没有执行到将得到的能量值加到目标能量盒中时资源就被其他线程抢占了,然而下下一条循环中,有可能将得到的能量值加到目标能量盒中,并执行到计算当前的总能量,因此,经过大量的循环,总能量就减少,也就是讲师所说的共享的数据被破坏。
能否发一下完整代码,我按照你的描述测试完,总能量一直是不变的,转移的能量也是在同步代码当中进行,也真的加到了目标能量盒当中。不知道你的跳跃输出是由于什么,睡眠时间的问题还是代码的问题?
深入浅出Java多线程
186078 学习 · 464 问题
相似问题