美文网首页
指令重排序

指令重排序

作者: 迷糊小生 | 来源:发表于2019-05-01 09:02 被阅读0次

在执行程序时,为了提高性能,编译器和处理器常常会对指令做重排序

重排序分以下3种类型:

编译器优化的重排序:编译器在不改变单线程程序语义的前提下,可以重新安排语句的执行顺序。

指令级并行的重排序:现代处理器采用了指令级并行技术来将多条指令重叠执行。如果不存在数据依赖性,处理器可以改变语句对应机器指令的执行顺序。

内存系统的重排序:由于处理器使用缓存和读/写缓冲区,这使得加载和存储操作看上去可能是在乱序执行。

从Java源代码到最终实际执行的指令序列,会分别经历下面3种重排序:


image.png

上述的1属于编译器重排序,2和3属于处理器重排序。

这些重排序可能会导致多线程程序出现内存可见性问题。对于编译器,JMM的编译器重排序规则会禁止特定类型的编译器重排序(不是所有的编译器重排序都要禁止)。

对于处理器重排序,JMM的处理器重排序规则会要求Java编译器在生成指令序列时,插入特定类型的内存屏障(Memory Barriers,Intel称之为Memory Fence)指令,通过内存屏障指令来禁止特定类型的处理器重排序。

JMM属于语言级的内存模型,它确保在不同的编译器和不同的处理器平台之上,通过禁止特定类型的编译器重排序和处理器重排序,为程序员提供一致的内存可见性保证。

-----------本文摘自《java并发编程的艺术》

相关文章

  • Java指令重排序

    Java指令重排序Java内存模型允许编译器和处理器对指令重排序以提高运行性能,并且只会对不存在数据依赖性的指令重...

  • 指令重排序和内存屏障

    一:指令重排序 指令乱序有两种情况,一种是编译器做的优化,另外一种就是cpu流水线操作指令的延迟性。指令重排序是指...

  • 我理解的volatile

    volatile语义 volatile有两层语义:可见性和禁止指令重排序。什么是可见性和指令重排序,在这里就不解释...

  • 指令重排序

    在执行程序时,为了提高性能,编译器和处理器常常会对指令做重排序。 重排序分以下3种类型: 编译器优化的重排序:编译...

  • 数组排序去重

    冒泡排序 sort排序 数组去重

  • 再学JS--数组去重

    双层循环 最原始的数组去重方式 indexOf 排序后去重 排序去去重是将数组进行sort排序,相同的值就会被排在...

  • 单例模式

    内部静态类 双锁验证 防止指令重排序 枚举

  • 重排序 VS 可见性 VS 原子性

    重排序 代码实际执行顺序和代码在 Java 文件中的顺序不一致,代码指令并不是严格按照代码语句顺序执行的,这就是重...

  • volatile

    保证内存可见性 禁止指令重排序 不能保证原子性

  • JAVA内存模型--指令重排序

    指令重排序 在执行程序时,为了提高性能,编译器和处理器会对指令做重排序。但是,JMM确保在不同的编译器和不同的处理...

网友评论

      本文标题:指令重排序

      本文链接:https://www.haomeiwen.com/subject/jlkknqtx.html