-
达内java培训课堂之并发处理技巧
发布:济南java培训 来源:济南java培训 时间:2016-07-19
-
Java内存模型是围绕着并发过程中如何处理原子性、可见性、有序性这三个特征来建立的,只要抓住这三个特性的特点就可以轻松地解决问题,三个特性的实现原理:
原子性:即一个操作或者多个操作要么全部执行并且执行的过程不会被任何因素打断,要么就都不执行。
在Java中,对基本数据类型的变量的读取和赋值操作是原子性操作,即这些操作是不可被中断的,要么执行,要么不执行。
上面一句话虽然看起来简单,但是理解起来并不是那么容易。看下面一个例子i:
请分析以下哪些操作是原子性操作:
1 x = 10; //语句1
2 y = x; //语句2
3 x++; //语句3
4 x = x + 1; //语句4
咋一看,有些朋友可能会说上面的4个语句中的操作都是原子性操作。其实只有语句1是原子性操作,其他三个语句都不是原子性操作。
语句1是直接将数值10赋值给x,也就是说线程执行这个语句的会直接将数值10写入到工作内存中。
语句2实际上包含2个操作,它先要去读取x的值,再将x的值写入工作内存,虽然读取x的值以及将x的值写入工作内存这2个操作都是原子性操作,但是合起来就不是原子性操作了。
同样的,x++和x = x+1包括3个操作:读取x的值,进行加1操作,写入新的值。
所以上面4个语句只有语句1的操作具备原子性。
也就是说,只有简单的读取、赋值(而且必须是将数字赋值给某个变量,变量之间的相互赋值不是原子操作)才是原子操作。
不过这里有一点需要注意:在32位平台下,对64位数据的读取和赋值是需要通过两个操作来完成的,不能保证其原子性。但是好像在最新的JDK中,JVM已经保证对64位数据的读取和赋值也是原子性操作了。
从上面可以看出,Java内存模型只保证了基本读取和赋值是原子性操作,如果要实现更大范围操作的原子性,可以通过synchronized和Lock来 实现。由于synchronized和Lock能够保证任一时刻只有一个线程执行该代码块,那么自然就不存在原子性问题了,从而保证了原子性。
可见性
可见性是指当多个线程访问同一个变量时,一个线程修改了这个变量的值,其他线程能够立即看得到修改的值。
于可见性,Java提供了volatile关键字来保证可见性。
当一个共享变量被volatile修饰时,它会保证修改的值会立即被更新到主存,当有其他线程需要读取时,它会去内存中读取新值。
而普通的共享变量不能保证可见性,因为普通共享变量被修改之后,什么时候被写入主存是不确定的,当其他线程去读取时,此时内存中可能还是原来的旧值,因此无法保证可见性。
另外,济南 达内java培训班项目经理提醒大家,通过synchronized和Lock也能够保证可� ��性,synchronized 和Lock能保证同一时刻只有一个线程获取锁然后执行同步代码,并且在释放锁之前会将对变量的修改刷新到主存当中。因此可以保证可见性。
有序性
有序性:即程序执行的顺序按照代码的先后顺序执行。
在Java内存模型中,允许编译器和处理器对指令进行重排序,但是重排序过程不会影响到单线程程序的执行,却会影响到多线程并发执行的正确性。
在Java里面,可以通过volatile关键字来保证一定的“有序性”(具体原理在下一节讲述)。另外可以通过synchronized和Lock来保 证有序性,很显然,synchronized和Lock保证每个时刻是有一个线程执行同步代码,相当于是让线程顺序执行同步代码,自然就保证了有序性。
文章来源:济南java培训
推荐文章
- 济南达内java培训课堂;济南java培训07.19
- 济南达内java培训如何07.19
- 济南达内java培训让你的起点更高07.19
- 达内java培训课堂之并发处理技巧07.19
- 【达内课堂】Swing框架中设计模式的误用07.19
相关文章
- 看大师如何评价java07.19
- 济南达内java培训课堂;济南java培训07.19
- 送给程序员的几点建议07.19
- 济南达内java培训课程有什么优势07.19
- 济南达内java培训如何07.19
- 济南达内java培训让你的起点更高07.19
最新资讯
达内新闻 | 更多
- + 中专生参加达内PHP培训,从车间工人到IT工程师实现职业梦想(07.15)
- + 看大师如何评价java(07.19)
- + 济南达内java培训课堂;济南java培训(07.19)
- + 送给程序员的几点建议(07.19)
- + 济南达内java培训课程有什么优势(07.19)
- + 济南达内java培训如何(07.19)








