Java原子操作AtomicInteger

一、问题引入

我们有一个自增的场景【data++】,单线程情况下我们的程序能正常运行,但多线程情况可能会出现线程1和线程2都是在操作一个变量data,但是线程1修改了data变量的值之后,线程2看不到修改,一直都是看到自己本地工作内存中的一个旧的副本的值,这样就好导致原子性问题。

我们通过一张图来简单描述下多线程情况下的内存模型:
Java原子操作AtomicInteger_第1张图片
在多线程中,所有线程共享主内存,每个线程有自己的工作内存。多个线程并发读写一个共享变量的时候,有可能某个线程修改了变量的值,但是其他线程看不到!也就是对其他线程不可见。

二、AtomicInteger

如何解决上面的问题呢?

很多同学可能想到了锁,锁可以解决我们的问题,但对于上面的自增场景,锁就有点大材小用了。

我们引入另一种解决方案AtomicInteger,AtomicInteger一个提供原子操作的Integer的类。在Java语言中,++i和i++操作并不是线程安全的,在使用的时候,不可避免的会用到synchronized关键字。而AtomicInteger则通过一种线程安全的加减操作接口。

我们看下AtomicInteger文档提供了哪些方法:

/**获取当前值*/
public final int get()/**设置为给定值*/
public final void set(int newValue);
/**最终设置为给定值*/
public final void lazySet(int newValue);
/**以原子方式设置为给定值并返回旧值*/
public final int getAndSet(int newValue);
/**以原子方式将当前值加一*/
public final int getAndIncrement();
/**以原子方式将当前值减一*/
public final int getAndDecrement();

针对我们开头提到的自增场景,我们通过AtomicInteger就能很简单的实现:

static AtomicInteger data= new AtomicInteger(0);

System.out.println("data:"+ data.getAndIncrement());

你可能感兴趣的:(Java)