java 多线程访问共享变量不安全因素分析

来源:互联网 发布:年轻的程序员 编辑:程序博客网 时间:2024/05/29 10:41

1. JVM 运行时内存区域决定

线程私有的内存区域

  1. 程序计数器
    当前线程所执行的字节码的行号指示器。
  2. Java虚拟机栈
    java方法执行的内存模型:每个方法在执行的同时都会创建一个栈帧用于存储局部变量表,操作数栈、动态链接、方法出口等信息。
  3. 本地方法栈
    是虚拟机执行native方法时所用到的内存模型
    线程共享的内存区域
  4. Java 堆
    是虚拟机所管理的内存中最大的一块。Java堆是被所有线程共享的一块区域,java堆主要用来存放对象实例,几乎所有的对象实例都在这里分配。
  5. 方法区
    是各个线程共享的内存区域,它用于存储已被虚拟机加载的类信息、常量、静态变量、即时编译器编译后的代码等数据。

因此:java多线程的不安全的因素之一是java堆,由于堆上的对象都是线程共享的,因此对于可变对象在多个线程同时访问时会造成对象状态的不一致。

2. 编译器和处理器为了尽可能提高代码的并行度,会对指令进行重排序,重排序的原则是只要在单线程环境下不破坏数据的依赖性

3.处理器为了提高程序的执行速度,在代码执行时,会把主内存的变量拷贝到处理器缓存中,当代码执行完成时,再把处理器缓存中的值写会到主内存。