JDK1.5 AtomicLong实例

Wesley13
• 阅读 462

JDK1.5 AtomicLong****实例

类 AtomicLong

可以用原子方式更新的 long 值。有关原子变量属性的描述,请参阅 java.util.concurrent.atomic 包规范。AtomicLong 可用在应用程序中(如以原子方式增加的序列号),并且不能用于替换 Long。但是,此类确实扩展了 Number,允许那些处理基于数字类的工具和实用工具进行统一访问。

常见方法

long addAndGet(long delta):以原子方式将给定值与当前值相加。

boolean compareAndSet(long expect, long update):如果当前值 == 预期值,则以原子方式将该值设置为给定的更新值。

long decrementAndGet():以原子方式将当前值减 1。

double doubleValue():以 double 形式返回指定的数值。

float floatValue():以 float 形式返回指定的数值。

long get():获取当前值。

软件包 java.util.concurrent.atomic

类的小工具包,支持在单个变量上解除锁定的线程安全编程。

类摘要

AtomicBoolean

可以用原子方式更新的 boolean 值。

AtomicInteger

可以用原子方式更新的 int 值。

AtomicIntegerArray

可以用原子方式更新其元素的 int 数组。

AtomicIntegerFieldUpdater

基于反射的实用工具,可以对指定类的指定 volatile int 字段进行原子更新。

AtomicLong

可以用原子方式更新的 long 值。

AtomicLongArray

可以用原子方式更新其元素的 long 数组。

AtomicLongFieldUpdater

基于反射的实用工具,可以对指定类的指定 volatile long 字段进行原子更新。

AtomicMarkableReference

AtomicMarkableReference 维护带有标记位的对象引用,可以原子方式对其进行更新。

AtomicReference

可以用原子方式更新的对象引用。

AtomicReferenceArray

可以用原子方式更新其元素的对象引用数组。

AtomicReferenceFieldUpdater<T,V>

基于反射的实用工具,可以对指定类的指定 volatile reference 字段进行原子更新。

AtomicStampedReference

AtomicStampedReference 维护带有整数“标志”的对象引用,可以原子方式对其进行更新。

实例1:

Java代码    JDK1.5 AtomicLong实例

  1. package com.bijian.thread;

  2. import java.util.concurrent.atomic.AtomicLong;

  3. import java.util.concurrent.locks.Lock;

  4. public class MyRunnable implements Runnable {

  5. private static AtomicLong aLong = new AtomicLong(10000); // 原子量,每个线程都可以自由操作

  6. private String name; // 操作人

  7. private int x; // 操作数额

  8. private Lock lock;

  9. MyRunnable(String name, int x, Lock lock) {

  10. this.name = name;

  11. this.x = x;

  12. this.lock = lock;

  13. }

  14. public void run() {

  15. System.out.println(name + "执行了" + x + ",当前余额:" + aLong.addAndGet(x));

  16. aLong.addAndGet(1);

  17. }

  18. }

Java代码    JDK1.5 AtomicLong实例

  1. package com.bijian.thread;

  2. import java.util.concurrent.ExecutorService;

  3. import java.util.concurrent.Executors;

  4. import java.util.concurrent.locks.Lock;

  5. import java.util.concurrent.locks.ReentrantLock;

  6. public class Main {

  7. public static void main(String[] args) {

  8. ExecutorService pool = Executors.newFixedThreadPool(2);

  9. Lock lock = new ReentrantLock(false);

  10. Runnable t1 = new MyRunnable("张三", 2000, lock);

  11. Runnable t2 = new MyRunnable("李四", 3600, lock);

  12. Runnable t3 = new MyRunnable("王五", 2700, lock);

  13. Runnable t4 = new MyRunnable("老张", 600, lock);

  14. Runnable t5 = new MyRunnable("老牛", 1300, lock);

  15. Runnable t6 = new MyRunnable("胖子", 800, lock);

  16. // 执行各个线程

  17. pool.execute(t1);

  18. pool.execute(t2);

  19. pool.execute(t3);

  20. pool.execute(t4);

  21. pool.execute(t5);

  22. pool.execute(t6);

  23. // 关闭线程池

  24. pool.shutdown();

  25. }

  26. }

运行结果:

Text代码    JDK1.5 AtomicLong实例

  1. 李四执行了3600,当前余额:13600
  2. 张三执行了2000,当前余额:15600
  3. 王五执行了2700,当前余额:18302
  4. 老张执行了600,当前余额:18903
  5. 老牛执行了1300,当前余额:20203
  6. 胖子执行了800,当前余额:21004

**应该是每个线程执行后都会执行aLong.addAndGet(1);****语句,但实际结果却不是这样的,原因是:虽然long addAndGet(long delta)**方法是以原子方式将给定值与当前值相加,但两条两句在一块,也只能表示它们各自的执行是原子级的,它们作为一个整体却不是原子级的。

于是,我们稍微修改一下MyRunnable类,给它加上锁,即可达到我们预想的目的,如下实例2所示。

实例2(修改MyRunnable类):

Java代码    JDK1.5 AtomicLong实例

  1. package com.bijian.thread;

  2. import java.util.concurrent.atomic.AtomicLong;

  3. import java.util.concurrent.locks.Lock;

  4. public class MyRunnable implements Runnable {

  5. private static AtomicLong aLong = new AtomicLong(10000); // 原子量,每个线程都可以自由操作

  6. private String name; // 操作人

  7. private int x; // 操作数额

  8. private Lock lock;

  9. MyRunnable(String name, int x, Lock lock) {

  10. this.name = name;

  11. this.x = x;

  12. this.lock = lock;

  13. }

  14. public void run() {

  15. lock.lock();

  16. System.out.println(name + "执行了" + x + ",当前余额:" + aLong.addAndGet(x));

  17. aLong.addAndGet(1);

  18. lock.unlock();

  19. }

  20. }

运行结果:

Text代码    JDK1.5 AtomicLong实例

  1. 张三执行了2000,当前余额:12000
  2. 李四执行了3600,当前余额:15601
  3. 王五执行了2700,当前余额:18302
  4. 老张执行了600,当前余额:18903
  5. 胖子执行了800,当前余额:19704
  6. 老牛执行了1300,当前余额:21005
点赞
收藏
评论区
推荐文章
blmius blmius
3年前
MySQL:[Err] 1292 - Incorrect datetime value: ‘0000-00-00 00:00:00‘ for column ‘CREATE_TIME‘ at row 1
文章目录问题用navicat导入数据时,报错:原因这是因为当前的MySQL不支持datetime为0的情况。解决修改sql\mode:sql\mode:SQLMode定义了MySQL应支持的SQL语法、数据校验等,这样可以更容易地在不同的环境中使用MySQL。全局s
皕杰报表之UUID
​在我们用皕杰报表工具设计填报报表时,如何在新增行里自动增加id呢?能新增整数排序id吗?目前可以在新增行里自动增加id,但只能用uuid函数增加UUID编码,不能新增整数排序id。uuid函数说明:获取一个UUID,可以在填报表中用来创建数据ID语法:uuid()或uuid(sep)参数说明:sep布尔值,生成的uuid中是否包含分隔符'',缺省为
待兔 待兔
5个月前
手写Java HashMap源码
HashMap的使用教程HashMap的使用教程HashMap的使用教程HashMap的使用教程HashMap的使用教程22
Jacquelyn38 Jacquelyn38
3年前
2020年前端实用代码段,为你的工作保驾护航
有空的时候,自己总结了几个代码段,在开发中也经常使用,谢谢。1、使用解构获取json数据let jsonData  id: 1,status: "OK",data: 'a', 'b';let  id, status, data: number   jsonData;console.log(id, status, number )
Wesley13 Wesley13
3年前
MySQL数据库InnoDB存储引擎Log漫游(1)
作者:宋利兵来源:MySQL代码研究(mysqlcode)0、导读本文介绍了InnoDB引擎如何利用UndoLog和RedoLog来保证事务的原子性、持久性原理,以及InnoDB引擎实现UndoLog和RedoLog的基本思路。00–UndoLogUndoLog是为了实现事务的原子性,
Wesley13 Wesley13
3年前
00:Java简单了解
浅谈Java之概述Java是SUN(StanfordUniversityNetwork),斯坦福大学网络公司)1995年推出的一门高级编程语言。Java是一种面向Internet的编程语言。随着Java技术在web方面的不断成熟,已经成为Web应用程序的首选开发语言。Java是简单易学,完全面向对象,安全可靠,与平台无关的编程语言。
Wesley13 Wesley13
3年前
JDK中的Atomic包中的类及使用
引言Java从JDK1.5开始提供了java.util.concurrent.atomic包,方便程序员在多线程环境下,无锁的进行原子操作。原子变量的底层使用了处理器提供的原子指令,但是不同的CPU架构可能提供的原子指令不一样,也有可能需要某种形式的内部锁,所以该方法不能绝对保证线程不被阻塞。Atomic包介绍在JDK1
Wesley13 Wesley13
3年前
MySQL部分从库上面因为大量的临时表tmp_table造成慢查询
背景描述Time:20190124T00:08:14.70572408:00User@Host:@Id:Schema:sentrymetaLast_errno:0Killed:0Query_time:0.315758Lock_
为什么mysql不推荐使用雪花ID作为主键
作者:毛辰飞背景在mysql中设计表的时候,mysql官方推荐不要使用uuid或者不连续不重复的雪花id(long形且唯一),而是推荐连续自增的主键id,官方的推荐是auto_increment,那么为什么不建议采用uuid,使用uuid究
Python进阶者 Python进阶者
11个月前
Excel中这日期老是出来00:00:00,怎么用Pandas把这个去除
大家好,我是皮皮。一、前言前几天在Python白银交流群【上海新年人】问了一个Pandas数据筛选的问题。问题如下:这日期老是出来00:00:00,怎么把这个去除。二、实现过程后来【论草莓如何成为冻干莓】给了一个思路和代码如下:pd.toexcel之前把这