zoukankan      html  css  js  c++  java
  • 重排序

    什么是重排序?重排序是指令的重排序。

    为了提高性能,编译器和处理器常常会对指令做重排序,重排序就会导致多线程执行的时候有数据不一致问题,导致程序结果不是理想结果。
     
    重排序分为三类:
    1. 编译器重排序:不改变单线程程序语义前提下,重新安排执行顺序
    2. 指令级并行重排序:指令并行技术可以将多条指令重叠执行,如果不存在数据依赖性,处理器会改变语句对应的机器指令执行顺序
    3. 内存系统重排序

    1 是属于编译器重排序,2 和 3 属于处理器重排序,都会引起多线程程序的内存可见性问题。

    对于编译器,JMM编译器会禁止特定类型的编译器重排序,对于处理器,JMM处理器重排序规则会要求Java编译器在生成指令的时候插入内存屏障指令来禁止特定的重排序。
    不同处理器重排序规则

    常见的处理都允许 store-load (写-读)进行重排序,都禁止有数据依赖的重排序

    内存屏障

    为了保证内存数据的可见性,JMM处理器重排序规则会要求Java编译器在生成指令的时候插入内存屏障指令来禁止特定的重排序。JMM中将内存屏障分为四类
    • LoadLoad Barriers
    • StoreStore Barriers
    • LoadStore Barriers
    • StoreLoad Barriers

  • 相关阅读:
    java 读取src下的配置文件
    图书管理系统
    StaticDemo
    MatixDemo
    Magics
    GetPrime
    ConWithThis
    TestTHIS
    ConstructorOverLoad
    Sequence
  • 原文地址:https://www.cnblogs.com/xiaojianfeng/p/9401551.html
Copyright © 2011-2022 走看看