thread12
来源:互联网 发布:网络投资理财可信吗 编辑:程序博客网 时间:2024/06/14 07:03
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); }}