写点什么

并发相关的性质学习笔记

用户头像
风翱
关注
发布于: 刚刚

并发相关的性质


原子性:原子操作,注意跟事务 ACID 里原子性的区别与联系

对基本数据类型的变量的读取和赋值操作是原子性操作,即这些操作是不可被中断的,要么执行,

要么不执行。


可见性:对于可见性,Java 提供了 volatile 关键字来保证可见性。

当一个共享变量被 volatile 修饰时,它会保证修改的值会立即被更新到主存,当有其他线程需要

读取时,它会去内存中读取新值。

另外,通过 synchronized 和 Lock 也能够保证可见性,synchronized 和 Lock 能保证同一时刻

只有一个线程获取锁然后执行同步代码,并且在释放锁之前会将对变量的修改刷新到主存当中。


有序性:Java 允许编译器和处理器对指令进行重排序,但是重排序过程不会影响到单线程程序的执行,却会影响到多线程并发执行的正确性。可以通过 volatile 关键字来保证一定的“有序性”(synchronized 和 Lock 也可以)。


happens-before 原则(先行发生原则):

1. 程序次序规则:一个线程内,按照代码先后顺序。

2. 锁定规则:一个 unLock 操作先行发生于后面对同一个锁的 lock 操作。

3. Volatile 变量规则:对一个变量的写操作先行发生于后面对这个变量的读操作。

4. 传递规则:如果操作 A 先行发生于操作 B,而操作 B 又先行发生于操作 C,则可以得出 A 先于 C。

5. 线程启动规则:Thread 对象的 start() 方法先行发生于此线程的每个一个动作。

6. 线程中断规则:对线程 interrupt() 方法的调用先行发生于被中断线程的代码检测到中断事件的发生。

7. 线程终结规则:线程中所有的操作都先行发生于线程的终止检测,我们可以通过 Thread.join() 方法结束、Thread.isAlive() 的返回值手段检测到线程已经终止执行。

8. 对象终结规则:一个对象的初始化完成先行发生于他的 finalize() 方法的开始。


发布于: 刚刚阅读数: 2
用户头像

风翱

关注

还未添加个人签名 2017.11.24 加入

勇于尝试,持续成长

评论

发布
暂无评论
并发相关的性质学习笔记