文档章节

java原子性操作理解

y
 yiqifendou
发布于 2016/09/29 18:49
字数 275
阅读 23
收藏 0
import java.util.concurrent.atomic.AtomicInteger;
import java.util.concurrent.atomic.AtomicLong;

/**
 * Created by wangzhongbao on 2016/9/28.
 */
public class TestAtomicOperate {
	private static int increCount = 1000000;
	//private static int num = 0;
	public static void main(String[] args) {
		TestAtomicOperate t = new TestAtomicOperate ();
		t.testDirectOperate(1000);
		t.testNotAtomicOperate(1000);
		t.testAtomicOperate(1000);

	}

	class NumRef{
		long num;
		public NumRef(long num){
			this.num = num;
		}
	}
	private int a = 0;
	private void testNotAtomicOperate(int threadCount){

		NumRef resultNr = new NumRef(0);
		AtomicInteger cai = new AtomicInteger(0);
		for(int i=0;i<threadCount;i++){
			new Thread(){
				@Override
				public void run() {
					for(int i=0;i<increCount;i++){
						resultNr.num++;
					}
					cai.incrementAndGet();
					if(cai.get()==threadCount){
						System.out.println("非原子性操作执行完毕,结果为: " + resultNr.num);
					}
				}
			}.start();
		}
	}

	private void testAtomicOperate(int threadCount){
		AtomicLong resultAi = new AtomicLong(0);
		AtomicInteger cai = new AtomicInteger(0);
		for(int i=0;i<threadCount;i++){
			new Thread(){
				@Override
				public void run() {
					for(int i=0;i<increCount;i++){
						resultAi.incrementAndGet();
					}
					cai.incrementAndGet();
					if(cai.get()==threadCount){
						System.out.println("原子性操作执行完毕,结果为:" + resultAi.get());
					}
				}
			}.start();
		}
	}
	private void testDirectOperate(int threadCount){
		long result = 0;
		for(int i=0;i<threadCount;i++){
			for(int j=0;j<increCount;j++){
				result++;
			}
		}
		System.out.println("单线程直接计算:"+result);
	}


}

执行结果如下:

单线程直接计算:1000000000

非原子性操作执行完毕,结果为: 984932415

原子性操作执行完毕,结果为:1000000000

由此可见:java里面 ++ 操作是非原子性的,线程不安全,所以java提供了AtomicInteger等类

© 著作权归作者所有

共有 人打赏支持
y
粉丝 5
博文 53
码字总数 9177
作品 0
南京
私信 提问
再有人问你synchronized是什么,就把这篇文章发给他。

在《深入理解Java虚拟机》中,有这样一段话: synchronized关键字在需要原子性、可见性和有序性这三种特性的时候都可以作为其中一种解决方案,看起来是“万能”的。的确,大部分并发控制操作...

Java填坑之路
2018/08/07
0
0
再有人问你Java内存模型是什么,就把这篇文章发给他!

前几天,发了一篇文章,介绍了一下JVM内存结构、Java内存模型以及Java对象模型之间的区别。有很多小伙伴反馈希望可以深入的讲解下每个知识点。Java内存模型,是这三个知识点当中最晦涩难懂的...

技术小能手
2018/09/30
0
0
Java开发中内存模型详细解析

Java内存模型虽说是一个老生常谈的问题 ,也是大厂面试中绕不过的,甚至初级面试也会问到。但是真正要理解起来,还是相当困难,主要这个东西看不见,摸不着。网上已经有大量的博客,但是人家...

金铭鼎IT教育
2018/12/17
0
0
Java并发学习之Volatile及内存模型探究

volatile工作原理 java编程语言允许线程访问共享变量,为了确保共享变量能被准确和一致的更新,线程应该确保通过排他锁单独获得这个变量。 Java语言提供了volatile,在某些情况下比锁更加方便...

小灰灰Blog
2017/11/02
0
0
再有人问你Java内存模型是什么,就把这篇文章发给他。

前几天,发了一篇文章,介绍了一下JVM内存结构、Java内存模型以及Java对象模型之间的区别。有很多小伙伴反馈希望可以深入的讲解下每个知识点。Java内存模型,是这三个知识点当中最晦涩难懂的...

Java架构
2018/07/11
0
0

没有更多内容

加载失败,请刷新页面

加载更多

centos7重置密码、单用户模式、救援模式、ls命令、chmod命令

在工作当中如果我们错误的配置了文件使服务器不能正常启动或者忘记密码不能登录系统,如何解决这些问题呢?重装系统是可以实现的,但是往往不能轻易重装系统的,下面用忘记密码作为例子讲解如...

李超小牛子
今天
1
0
Python如何开发桌面应用程序?Python基础教程,第十三讲,图形界面

当使用桌面应用程序的时候,有没有那么一瞬间,想学习一下桌面应用程序开发?行业内专业的桌面应用程序开发一般是C++,C#来做,Java开发的也有,但是比较少。本节课会介绍Python的GUI(图形用...

程序员补给栈
今天
5
0
kafka在的使用

一、基本概念 介绍 Kafka是一个分布式的、可分区的、可复制的消息系统。它提供了普通消息系统的功能,但具有自己独特的设计。 这个独特的设计是什么样的呢? 首先让我们看几个基本的消息系统...

狼王黄师傅
今天
3
0
Android JNI总结

0x01 JNI介绍 JNI是Java Native Interface的缩写,JNI不是Android专有的东西,它是从Java继承而来,但是在Android中,JNI的作用和重要性大大增强。 JNI在Android中起着连接Java和C/C++层的作...

天王盖地虎626
昨天
3
0
大数据教程(11.8)Hive1.2.2简介&初体验

上一篇文章分析了Hive1.2.2的安装,本节博主将分享Hive的体验&Hive服务端和客户端的使用方法。 一、Hive与hadoop直接的关系 Hive利用HDFS存储数据,利用MapReduce查询数据。 二、Hive与传统数...

em_aaron
昨天
4
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部