• 最新公告
  • 联系我们
  • 地址:湖北武汉三环科技园
  • 电话:159116031100
  • 传真:027-68834628
  • 邮箱:mmheng@foxmail.com
  • 当前所在位置:首页 - 商业委托
  • java并发的 处理技巧-
  •    Java内存模型是围绕着并发过程中如何处理原子性、可见性、有序性这三个特征来建立的 ,下面是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关键字来保证可见性。 ,广州北大青鸟Java是一个广泛使用的网络编程语言,它是一种新的计算概念。首先,作为一种程序设计语言,它简单、面向对象、不依赖于机器的结构、具有可移植性、鲁棒性、安全性、并且提供了并发的机制、具有很高的性能。其次,它最大限度地利用了网络,Java的小应用程序(applet)可在网络上传输而不受CPU和环境的限制。另外,Java还提供了丰富的类库,使程序设计者可以很方便地建立自己的系统。;  当一个共享变量被volatile修饰时,它会保证修改的 值会立即被更新到主存,当有其他线程需要读取时,它会去内存中读取新值。   而普通的 共享变量不能保证可见性,因为普通共享变量被修改之后,什么时候被写入主存是不确定的 ,当其他线程去读取时,此时内存中可能还是原来的 旧值,因此无法保证可见性。   另外,Java培训教育机构专家提醒大家,通过synchronized和Lock也能够保证可见性,synchronized和Lock能保证同一时刻只有一个线程获取锁然后执行同步代码,并且在释放锁之前会将对变量的 修改刷新到主存当中。因此可以保证可见性。   有序性   有序性即程序执行的 顺序按照代码的 先后顺序执行。
      在Java内存模型中,允许编译器和处理器对指令进行重排序,但是重排序过程不会影响到单线程程序的 执行,却会影响到多线程并发执行的 正确性。   在Java里面,可以通过volatile关键字来保证一定的 “有序性”(具体原理在下一节讲述)。另外可以通过synchronized和Lock来保证有序性,很显然,synchronized和Lock保证每个时刻是有一个线程执行同步代码,相当于是让线程顺序执行同步代码,自然就保证了有序性。