
volatile关键字不能保证原子性,synchronized可以保证原子性,但是比较消耗资源。
Atomic工具类可以安全有效的解决原子性问题
基本用法:
/** * Atomic工具类可以有效安全的解决数据的原子性问题 */ public class AtomicDemo { public static void main(String[] args) { // 初始化一个默认值为0的原子型Integer AtomicInteger a1 = new AtomicInteger(); // 初始化一个指定值的原子型Integer AtomicInteger a2 = new AtomicInteger(10); // int get():获取值 System.out.println(a1.get());// 0 // int getAndIncrement():以原子方式将当前值加1,返回自增前的值 int andIncrement = a1.getAndIncrement(); System.out.println(andIncrement);// 0 System.out.println(a1.get());// 1 // int incrementAndGet():以原子方式将当前值加1,返回自增后的值 int incrementAndGet = a2.incrementAndGet(); System.out.println(incrementAndGet);// 11 // int andAndGet():以原子方式将参数与对象中的值相加,并返回结果 int addAndGet = a2.addAndGet(2); System.out.println(addAndGet);// 13 // int getAndSet():以原子方式设置为newValue的值,并返回旧值 int andSet = a2.getAndSet(100); System.out.println(andSet);// 13 System.out.println(a2.get());// 100 } }
示例:
public static void main(String[] args) { RunnableDemo rd = new RunnableDemo(); for (int i = 0; i < 100; i++) { new Thread(rd).start(); } } public class RunnableDemo implements Runnable { AtomicInteger ai = new AtomicInteger(0); @Override public void run() { for (int i = 0; i < 100; i++) { int count = ai.incrementAndGet(); System.out.println("卖了" + count + "朵玫瑰花"); } } }

