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

  • 相关阅读:
    windows测试模式
    架构设计之Spring-Session的分布式集群会话管理
    WPF集合
    java Socket Udp
    java Socket 获取本地主机ip
    快速排序
    java 正则举例
    JNI 在命令行窗口输入字符,不显所输入字符,显指定的掩饰符
    java 在控制台上输入密码时,密码不显示在控制台上
    java 获取对象大小
  • 原文地址:https://www.cnblogs.com/xiaojianfeng/p/9401551.html
Copyright © 2011-2022 走看看