js 原子级操作_高并发系列之——原子操作

jdk:1.8.0_65

1 前言

首先需要了解什么是原子性,可以理解为CPU层面不能分割的操作,原子性只有两种状态,要么改变,要么不改变。如果多线程同时更新同一个变量,非原子操作都会出现线程安全问题,导致多线程执行后获取到的变量值与期望值不一致。

那么如何解决线程安全问题呢,可以实现一个原子操作,有三种方式:

第一种:使用同步技术,sychronized代码块。

第二种:lock接口。

第三种:原子数据结构,如AtomicBoolean、AtomicInteger、AtomicLong等。

以下是针对原子数据结构进行解读。

2.原子数据结构

原子数据在jdk中包路径为java.util.concurrent.atomic,原子数据结构类都是使用Unsafe实现的包装类,有11个类,可以分为四种,以下为各个类型的讲解。

2.1 原子更新基本类型

AtomicBoolean:更新的 boolean 值。适用于多线程中状态控制,如销毁或是执行状态。

AtomicInteger:更新的 int 值。常用于资源数量的控制操作,如线程池中资源数量,以此来判断新的任务是否加入线程池中。

AtomicLong:更新的 long 值。

2.2 原子更新数组——更新数组中指定的值

AtomicIntegerArray:更新其元素的 int 数组。

AtomicLongArray:更新其元素的 long 数组。

2.3 原子更新引用类型——更新多

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值