AtomicInteger时随着jdk5.0出来的,它位于java.util.concurrent.atomic包下,AtomicInteger,一个提供原子操作的Integer的类。也就是说在Java语言中,++i和i++操作并不是线程安全的,在使用的时候,不可避免的会用到synchronized关键字。而AtomicInteger则通过一种线程安全的加减操作接口,也就是说当有多个线程操作同一个变量时,使用AtomicInteger不会导致变量出现问题,而且比使用 synchronized效率高,现在就看一个例子:
package cn.kge.com; import java.util.concurrent.atomic.AtomicInteger; public class AtomicDemo { public final static AtomicInteger atomicInteger = new AtomicInteger(1); public static void main(String[] args) throws InterruptedException { final Thread []threads = new Thread[10]; for(int i = 0 ; i < 10 ; i++) { final int num = i; threads[i] = new Thread() { public void run() { try { Thread.sleep(1000); } catch (InterruptedException e) { e.printStackTrace(); } int now = atomicInteger.incrementAndGet(); System.out.println("我是线程:" + num + ",我得到值了,增加后的值为:" + now); } }; threads[i].start(); } for(Thread t : threads) { t.join(); } System.out.println("最终运行结果:" + atomicInteger.get()); } }
运行结果是:
我是线程:1,我得到值了,增加后的值为:2
我是线程:2,我得到值了,增加后的值为:3
我是线程:0,我得到值了,增加后的值为:4
我是线程:9,我得到值了,增加后的值为:5
我是线程:5,我得到值了,增加后的值为:6
我是线程:4,我得到值了,增加后的值为:7
我是线程:8,我得到值了,增加后的值为:8
我是线程:3,我得到值了,增加后的值为:9
我是线程:7,我得到值了,增加后的值为:10
我是线程:6,我得到值了,增加后的值为:11
最终运行结果:11
为什么会是11呢?因为他构造函数中初始化就为1,然后有10个线程,每个线程都加1,就是11了,这就是单个线程执行时,atomicinteger加1不会出现问题,
AtomicInteger使用注意地方就是在你创建AtomicInteger对象时是作为成员变量使用的,不要再局部区域使用此对象!