JUC学习笔记 -- (2)并发编程的3个概念 ,原子性,可见性,有序性!

本文介绍了Java并发编程中的三个关键概念:原子性、可见性和有序性。原子性确保操作不可中断,可通过`synchronized`和`Lock`实现;可见性保证多线程间变量修改的可见性,避免缓存导致的问题;有序性涉及指令重排序,处理器会保证数据依赖性。理解并保证这三个特性是编写正确并发程序的基础。
摘要由CSDN通过智能技术生成

并发编程中的三条性质:原子性,可见性,有序性

1.原子性

原子性:即一个操作或者多个操作 要么全部执行并且执行的过程不会被任何因素打断,要么就都不执行。即整体不可分割。

Java中,对基本数据类型(例外就是long和double的非原子协定)的变量的读取和赋值操作是原子性操作

X=10;  //原子性(简单的读取、将数字赋值给变量)

Y = x;  //变量之间的相互赋值,不是原子操作

X++;  //对变量进行计算操作

X = x+1;

语句2实际包括两个操作,它先要去读取x的值,再将y值写入,两个操作分开是原子性的。合在一起就不是原子性的。

语句3、4:x++  x=x+1包括3个操作:读取x的值,x+1,将x写入

注:可以通过 synchronized和Lock实现原子性。因为synchronized和Lock能够保证任一时刻只有一个线程访问该代码块。

Java的concurrent包下提供了一些原子类,我们可以通过阅读API来了解这些原子类的用法。比如:AtomicInteger、AtomicLong、AtomicReference等。

2.可见性

可见性是指当多个线程访问同一个变量时,一个线程修改了这个变量的值,其他线程能够立即看得到修改的值。

举个简单的例子,看下面这段代码:

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值