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

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

线程私有的内存区域

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

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

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

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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值