JAVA多线程与并发学习总结

JAVA多线程与并发学习总结

ID:42465840

大小:106.32 KB

页数:19页

时间:2019-09-15

JAVA多线程与并发学习总结_第1页
JAVA多线程与并发学习总结_第2页
JAVA多线程与并发学习总结_第3页
JAVA多线程与并发学习总结_第4页
JAVA多线程与并发学习总结_第5页
资源描述:

《JAVA多线程与并发学习总结》由会员上传分享,免费在线阅读,更多相关内容在工程资料-天天文库

1、计算机系统使用高速缓存来作为内存与处理器之间的缓冲,将运算需要用到的数据复制到缓存中,让计算能快速进行;当运算结束后再从缓存同步回内存之中,这样处理器就无需等待缓慢的内存读写了。缓存一致性:多处理器系统中,因为共享同一主内存,当多个处理器的运算任务都设计到同一块内存区域时,将可能导致各自的缓存数据不一致的情况,则同步回主内存时需要遵循一些协议。乱序执行优化:为了使得处理器内部的运算单位能尽量被充分利用。2.JAVA内存模型目标是定义程序中各个变量的访问规则。(包括实例字段、静态字段和构成数组的元素,不包括局部变量和方法参数)1.所有的变量都存储在主内存中(虚拟机内存的一部分)。2.每条线程

2、都由自己的工作内存,线程的工作内存中保存了该线程使用到的变量的主内存副本拷贝,线程对变量的所有操作都必须在工作内存中进行,而不能直接读写主内存中的变量。3.线程之间无法直接访问对方的工作内存中的变量,线程间变量的传递均需耍通过主内存来完成。内存间交互操作:Lock(锁定):作用于主内存中的变量,把一个变量标识为一条线程独占的状态。Read(读取):作用于主内存中的变量,把一个变量的值从主内存传输到线程的工作内存中。Load(加载):作用于工作内存中的变量,把read操作从主内存中得到的变量的值放入工作内存的变量副本中。Use(使用):作用于工作内存中的变量,把工作内存中•个变量的值传递给执

3、行引擎。Assign(赋值):作用于工作内存中的变量,把一个从执行引擎接收到的值赋值给工作内存中的变量。Store(存储):作用于工作内存中的变量,把工作内存中的一个变量的值传送到主内存中。Write(写入):作用于主内存屮的变量,把store操作从工作内存屮得到的变量的值放入主内存的变量中。Unlock(解锁):作用于主内存中的变量,把一个处于锁定状态的变量释放出来,之后可被其它线程锁定。规则:1・不允许read和load>store和write操作之一单独出现。2.不允许一个线程丢弃最近的assign操作,变量在工作内存中改变了之后必须把该变化同步回主内存中。3.不允许一个线程没有发生

4、过任何assign操作把数据从线程的工作内存同步冋主内存屮。4•一个新的变量只能在主内存中诞生。5.一个变量在同一时刻只允许一条线程对其进行lock操作,但可以被同一条线程重复执行多次。6.如果对一个变量执行lock操作,将会清空工作内存中此变量的值,在执行引擎使用这个变量前,需要重新执行read、load操作。7.如果一个变量事先没有被lock操作锁定,则不允许对它执行unlock操作。8.8.对一个变量执行unlock操作前,必须先把该变量同步回主内存中。3.volatile型变量1・保证此变量对所有线程的可见性。每条线程使用此类型变量前都需要先刷新,执行引擎看不到不一致的情况。运算结

5、果并不依赖变量的当前值、或者确保只有单一的线程修改变量的值。变量不需要与其他的状态变量共同参与不变约朿。1・禁止指令重排序优化。普通的变量仅保证在方法执行过程中所有依赖氏值结果的地方都能获取到正确的结果。而不能保证赋值操作的顺序与程序代码中的顺序一致。2.load必须与use同时出现;assign和store必须同时出现。2.原子性、可见性与有序性原子性:基木数据类型的访问读写是具备原子性的synchronized块之间的操作也具备原子性。可见性:指当一个线程修改了共享变量的值,其他线程能够立即得知这个修改oSynchronized(规则8)和final可以保证可见性□Final修饰的字段

6、在构造器中一旦被初始化完成,并且构造器没有把this的引用传递出去,那么在其他线程中就能看见final字段的值。有序性:volatile本身包含了禁止指令重排序的语义,而synchronized则是由规则5获得的,这个规则决定了持有同一个所的两个同步块只能串行地进入。5・先行发生原则Java内存模型屮定义的两项操作之间的偏序关系,如果操作A先行发生于操作B,其实就是说在发主操作B之前,操作A产生的影响能被操作B观察到。程序次序规则:在一个线程内,按照代码控制流顺序,在前面的操作先行发生于后面的操作。管程锁定规则:一个unlock操作先行发生于后而对同一个锁的lock操作。Volatile变

7、量规则:对一个volatile变量的写操作先行发生于后而对这个变量的读操作。线程启动规则:Thread对象的start()方法先行发生于此线程的每个操作。线程终止规则:线程中的所有操作都先行发生于对此线程的终止检测。线程中断规则:对线程的interrupt()方法的调用先行发生于被中断线程的代码检测中断事件的发生。对象终结过则:一个对象的初始化完成先行发生于它的finalize()方法的开始。传递性:如果操作A先行发生于

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。