Java中volatile关键字如何实现并发控制?
- 内容介绍
- 文章标签
- 相关推荐
本文共计1254个文字,预计阅读时间需要6分钟。
引言:说到多线程程序,我认为我们最重要的是理解一个概念——线程间的竞争关系。
举例来说,一个班级上有1个女孩子(线程),49个男孩子(线程),男孩子的目标就是那个女孩子,这就形成了竞争关系。
引言
说到多线程,我觉得我们最重要的是要理解一个临界区概念。
举个例子,一个班上1个女孩子(临界区),49个男孩子(线程),男孩子的目标就是这一个女孩子,就是会有竞争关系(线程安全问题)。推广到实际场景,例如对一个数相加或者相减等等情形,因为操作对象就只有一个,在多线程环境下,就会产生线程安全问题。理解临界区概念,我们对多线程问题可以有一个好意识。
Jav内存模型(JMM)
谈到多线程就应该了解一下Java内存模型(JMM)的抽象示意图.下图:
线程A和线程B执行的是时候,会去读取共享变量(临界区),然后各自拷贝一份回到自己的本地内存,执行后续操作。
JMM模型是一种规范,就像Java的接口一样。JMM会涉及到三个问题:原子性,可见性,有序性。
所谓原子性。就是说一个线程的执行会不会被其他线程影响的。他是不可中断的。举个例子:
int i=1
这个语句在Jmm中就是原子性的。无论是一个线程执行还是多个线程执行这个语句,读出来的i就是等于1。那什么是非原子性呢,按道理如果Java的代码都是原子性,应该就不会有线程问题了啊。其实JMM这是规定某些语句是原子性罢了。举个非原子性例子:
i ++;
这个操作就不是原子性的了。
本文共计1254个文字,预计阅读时间需要6分钟。
引言:说到多线程程序,我认为我们最重要的是理解一个概念——线程间的竞争关系。
举例来说,一个班级上有1个女孩子(线程),49个男孩子(线程),男孩子的目标就是那个女孩子,这就形成了竞争关系。
引言
说到多线程,我觉得我们最重要的是要理解一个临界区概念。
举个例子,一个班上1个女孩子(临界区),49个男孩子(线程),男孩子的目标就是这一个女孩子,就是会有竞争关系(线程安全问题)。推广到实际场景,例如对一个数相加或者相减等等情形,因为操作对象就只有一个,在多线程环境下,就会产生线程安全问题。理解临界区概念,我们对多线程问题可以有一个好意识。
Jav内存模型(JMM)
谈到多线程就应该了解一下Java内存模型(JMM)的抽象示意图.下图:
线程A和线程B执行的是时候,会去读取共享变量(临界区),然后各自拷贝一份回到自己的本地内存,执行后续操作。
JMM模型是一种规范,就像Java的接口一样。JMM会涉及到三个问题:原子性,可见性,有序性。
所谓原子性。就是说一个线程的执行会不会被其他线程影响的。他是不可中断的。举个例子:
int i=1
这个语句在Jmm中就是原子性的。无论是一个线程执行还是多个线程执行这个语句,读出来的i就是等于1。那什么是非原子性呢,按道理如果Java的代码都是原子性,应该就不会有线程问题了啊。其实JMM这是规定某些语句是原子性罢了。举个非原子性例子:
i ++;
这个操作就不是原子性的了。

