并发学习笔记1-竞态条件和数据竞争
在学习中学到两个名词:竞态条件,数据竞争。
这两个在一定情况下程序会同时出现,在书中对这个的解释也不够明确,这里记录对这两个名词的个人理解。
- 竞态条件:可以理解为原子性问题,假设a=0,当线程A 执行++a还没执行完,线程B就执行了,这时线程B拿到的a是旧的,造成的和我们预想的结果不一致
- 数据竞争:可以理解为可见性问题,同样a=0,此时线程A执行++a,这时线程B需要这个变量a做另外的操作,由于线程A中a还在栈内存还没刷到主内存,线程B拿到的还是a失效的值
解决方法:使用原子变量类,同步锁,和volatile 修饰变量