为什么Java多线程需要同步?
来源:互联网 发布:电脑手机拨号软件 编辑:程序博客网 时间:2024/05/01 02:41
分类: java 2012-02-10 16:18 103人阅读 评论(0)收藏举报
Java线程共享数据需要同步的根本原因在于Java内存的设计。根据JVM的规范,java的内存既有主存又有线程工作内存,其关系如下图:
( 网上找的图,图中的save应为store)
可以看到,主存是多个线程共享的,线程之间是不能有数据通讯的,它们之间的数据交换只能通过读写主存中的变量来解决,那么线程工作内存是如何与主存交互的呢?
为完成这种交互,JVM规范了6种原子行为,分别是:use,assign, load, store, read, write,另外还有lock, unlock两种原子行为,是关于同步的,这里不再讨论。use, assign, load, store是线程可执行的行为,read, write是主存可执行的行为。
一个线程从主存拷贝变量到工作内存运算并写回主存的过程如下:主存拷贝变量(read)—> 线程载入变量到其工作内存(load)—> 线程使用变量参与运算(use) –> 线程改变变量值(assign) –> 线程传输变量值到主存(store) –> 主存修改变量值(write)。
由此可见,一个线程对变量的修改需要经历6个步骤,这6个步骤是可以被分割的,当执行到其中一步时,如果刚好有其它线程被执行并改变了变量值,那么变量值将不再是符合我们结果的,因此多线程对共享资源需要同步。
- 为什么Java多线程需要同步?
- 为什么Java多线程需要同步?
- java为什么需要多线程
- java中为什么需要多线程
- 为什么需要同步?
- Java多线程初学:数据为什么要同步?(转载)
- 为什么需要多线程编程模型
- 开发中为什么需要多线程?
- 为什么需要学习JAVA
- 为什么CDMA需要对整个网络同步
- JAVA多线程同步小议
- java多线程同步机制
- 控制java多线程同步
- Java多线程(数据同步)
- java多线程同步
- java多线程同步
- Java 多线程同步
- Java多线程同步
- 用C++Builder写C/S遇到的问题
- C语言中可变参数的用法
- C++派生类--基类构造函数,内嵌对象(子对象)的执行顺序
- 继承与派生
- 对象指针
- 为什么Java多线程需要同步?
- 【ZT】哈哈,太搞笑了,咆哮体~~
- C语言中time函数【转载】
- Android安装过程
- 个人开公司的流程,以后用得着
- explicit构造函数
- meta标签之详解
- 广州软件测试俱乐部-图书室免费开放
- html meta标签属性用法集合