如果理解java中的同步
如果理解java中的同步
李雷岗 发表于1年前
如果理解java中的同步
  • 发表于 1年前
  • 阅读 25
  • 收藏 0
  • 点赞 0
  • 评论 0

腾讯云 技术升级10大核心产品年终让利>>>   

java的同步说白了就是要保证运行程序的顺序一致性

顺序一致性:顺序一致性模型是被计算机科学家理想化的理论参考模型,为程序员提供了极强的内存可见性保证,两大特性:

  •     一个线程中的所有操作必须按照程序的顺序来执行
  • 不管程序是否同步,所有的线程都只能看到一个单一的操作执行顺序,在顺序一致性内存模型中,每个操作必须是原子执行并且立即对所有的线程可见。   

但是JMM本身没有对多线程下的执行顺序做一致性的保证,在顺序一致性模型中,所有操作完全按照程序顺序串行执行,在JMM中,临界区的代码可以重新排序,单会在临界区的时间点做一些特殊处理,保证虽然在临界区内做了重排序,但是由于监视器的互斥特性,B无法观察到A的重排序,既提高了执行效率,有没有改变执行的结果。

   但是如果没有执行同步操作,JMM不保证执行结果跟顺序一致性模型的结果一样,因为这样的话,就需要禁用大量的处理器和编译器的优化,对执行的性能会产生很大的影响。未同步的程序在顺序一致性模型中,整体是无序的。结果无法预知,保证未同步程序的两个模型的执行结果没什么意义。

如何理解上边这段话呢,我的看法是这样,顺序一致性模型的是理想的模型,但是现实很骨感,如果要做大这种模型,就对于处理器的优化和编译器的优化造成很大的影响,但是如果单单是为了同步这个事儿,把这些优化都给取消掉了的话,得不偿失。这也可以理解成为什么java语言再设计的时候干嘛不直接把这些需要考虑的同步问题都给屏蔽了呢,直接让语言来保证这个,就是因为这涉及到大量的处理器的的指令优化的损失。

    java的同步机制呢,就是设法,在专门对于临界操作的时候呢做一些处理,保证他看着跟顺序一致性水样的但是还不影响大执行的优化,编译器的优化。

 

 

 

 

 

共有 人打赏支持
粉丝 2
博文 34
码字总数 22317
×
李雷岗
如果觉得我的文章对您有用,请随意打赏。您的支持将鼓励我继续创作!
* 金额(元)
¥1 ¥5 ¥10 ¥20 其他金额
打赏人
留言
* 支付类型
微信扫码支付
打赏金额:
已支付成功
打赏金额: