您的位置:首页 > 编程语言 > Java开发

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

2017-07-09 20:12 411 查看

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

线程私有的内存区域

程序计数器

当前线程所执行的字节码的行号指示器。

Java虚拟机栈

java方法执行的内存模型:每个方法在执行的同时都会创建一个栈帧用于存储局部变量表,操作数栈、动态链接、方法出口等信息。

本地方法栈

是虚拟机执行native方法时所用到的内存模型

线程共享的内存区域

Java 堆

是虚拟机所管理的内存中最大的一块。Java堆是被所有线程共享的一块区域,java堆主要用来存放对象实例,几乎所有的对象实例都在这里分配。

方法区

是各个线程共享的内存区域,它用于存储已被虚拟机加载的类信息、常量、静态变量、即时编译器编译后的代码等数据。

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

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

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

内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  java