atomicinteger线程安全_谈谈Java原子操作AtomicInteger

0e9953bdab25f04e2388df8ad873eac2.png

一、问题引入

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

我们通过一张图来简单描述下多线程情况下的内存模型:

98d790bcc2116698b4a623909b600d8a.png

在多线程中,所有线程共享主内存,每个线程有自己的工作内存。多个线程并发读写一个共享变量的时候,有可能某个线程修改了变量的值,但是其他线程看不到!也就是对其他线程不可见。

二、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());

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值