为什么Java多线程需要同步?

       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个步骤是可以被分割的,当执行到其中一步时,如果刚好有其它线程被执行并改变了变量值,那么变量值将不再是符合我们结果的,因此多线程对共享资源需要同步。

         关于JVM的规范中此部分内容,见http://java.sun.com/docs/books/jvms/second_edition/html/Threads.doc.html

  • 3
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值