博客
关于我
Java中线程安全的体现(原子性、可见性、有序性)
阅读量:587 次
发布时间:2019-03-11

本文共 761 字,大约阅读时间需要 2 分钟。

0、相关文章:

(1.8w阅读量,12赞)

(5k阅读量,4赞)

1、线程安全在三个方面体现

1.1、原子性:

提供互斥访问,同一时刻只能有一个线程对数据进行操作(atomic [əˈtɑːmɪk] 、synchronized);

1.2、可见性:

一个线程对主内存的修改可以及时地被其他线程看到(synchronized、volatile);

1.3、.有序性:

一个线程观察其他线程中的指令执行顺序,由于指令重排序,该观察结果一般杂乱无序,(happens-before原则)。

2、原子性

原子性的实现有两种方式:atomic类和synchronized。

2.1、JDK里面提供了很多atomic类,AtomicInteger,AtomicLong,AtomicBoolean等等,它们是通过CAS完成原子性。

2.2、synchronized是一种同步锁,通过锁实现原子操作。

JDK提供锁分两种:一种是synchronized,依赖JVM实现锁,因此在这个关键字作用对象的作用范围内是同一时刻只能有一个线程进行操作;另一种是LOCK,是JDK提供的代码层面的锁,依赖CPU指令,代表性的是ReentrantLock。

synchronized修饰的对象有四种:

  • (1)修饰代码块,作用于调用的对象;
  • (2)修饰方法,作用于调用的对象;
  • (3)修饰静态方法,作用于所有对象;
  • (4)修饰类,作用于所有对象。

3、可见性

对于可见性,JVM提供了synchronized和volatile。

4、有序性

有序性是指,在JVM中,允许编译器和处理器对指令进行重排序,但是重排序过程不会影响到单线程程序的执行,却会影响到多线程并发执行的正确性。

可以通过volatile、synchronized、lock保证有序性。

转载地址:http://yjvtz.baihongyu.com/

你可能感兴趣的文章
mysql索引创建和使用注意事项
查看>>
MySQL索引原理以及查询优化
查看>>
Mysql索引合并(index merge)导致的死锁问题
查看>>
mysql索引底层数据结构和算法
查看>>
Mysql索引底层结构的分析
查看>>
MySQL索引底层:B+树详解
查看>>
Mysql索引总结
查看>>
mysql索引最左匹配原则理解以及常见的sql使用的索引情况的实测
查看>>
Mysql索引类型
查看>>
MySQL索引背后的数据结构及算法原理
查看>>
mysql索引能重复吗_mysql “索引”能重复吗?“唯一索引”与“索引”区别是什么?...
查看>>
mysql级联删除_Mysql笔记系列,DQL基础复习,Mysql的约束与范式
查看>>
mysql经常使用命令
查看>>
MySQL经常使用技巧
查看>>
mysql给账号授权相关功能 | 表、视图等
查看>>
MySQL缓存使用率超过80%的解决方法
查看>>
Mysql缓存调优的基本知识(附Demo)
查看>>
mysql网站打开慢问题排查&数据库优化
查看>>
mysql网络部分代码
查看>>
mysql联合索引的最左前缀匹配原则
查看>>