package com.neutron.t12;
import java.util.ArrayList;
import java.util.List;
import java.util.concurrent.atomic.AtomicInteger;
/**
* 讲解内容:AtomXXX
* 因为++,--等操作不具备原子性,所以可以使用如下替代方式。
* AtomXXX类本身的方法都是原子性,但不能保证多个方法连续调用是原子性。
*
*/
public class T12 {
AtomicInteger count = new AtomicInteger(0);
void mm() {
for (int i = 0; i < 1000; i++) {
count.incrementAndGet(); //代替count++,保证原子性操作
// 注意下面则不构成原子性,因为在get时,线程a进行判断后,但是不执行下面代码
// 线程b进行判断,执行完代码,此时代码是1000,然后线程a执行,此时结果是1001
/*if (count.get() > 1000) {
count.incrementAndGet();
}*/
}
}
/**
预期结果:
count: 10000
运行结果:
count: 10000
开启10个线程,每个线程执行1000次,预期结果是10000
1.使用 count.incrementAndGet();保证数据原子性操作
*/
public static void main(String[] args) {
T12 t11 = new T12();
List<Thread> threads = new ArrayList<>(10);
for (int i = 0; i < 10; i++) {
threads.add(new Thread(t11::mm, "thread" + i));
}
threads.forEach(o -> o.start());
threads.forEach((o) -> {
try {
o.join();
} catch (InterruptedException e) {
e.printStackTrace();
}
});
System.out.println("count: " + t11.count);
}
}
thread12 - AtomXXX
最新推荐文章于 2024-01-02 23:27:24 发布