java 多线程访问共享变量不安全因素分析
2017-07-09 20:12
411 查看
1. JVM 运行时内存区域决定
线程私有的内存区域程序计数器
当前线程所执行的字节码的行号指示器。
Java虚拟机栈
java方法执行的内存模型:每个方法在执行的同时都会创建一个栈帧用于存储局部变量表,操作数栈、动态链接、方法出口等信息。
本地方法栈
是虚拟机执行native方法时所用到的内存模型
线程共享的内存区域
Java 堆
是虚拟机所管理的内存中最大的一块。Java堆是被所有线程共享的一块区域,java堆主要用来存放对象实例,几乎所有的对象实例都在这里分配。
方法区
是各个线程共享的内存区域,它用于存储已被虚拟机加载的类信息、常量、静态变量、即时编译器编译后的代码等数据。
因此:java多线程的不安全的因素之一是java堆,由于堆上的对象都是线程共享的,因此对于可变对象在多个线程同时访问时会造成对象状态的不一致。
2. 编译器和处理器为了尽可能提高代码的并行度,会对指令进行重排序,重排序的原则是只要在单线程环境下不破坏数据的依赖性
3.处理器为了提高程序的执行速度,在代码执行时,会把主内存的变量拷贝到处理器缓存中,当代码执行完成时,再把处理器缓存中的值写会到主内存。
相关文章推荐
- java多线程的共享变量访问控制实例
- Java多线程编程:变量共享分析(Thread)
- Java多线程编程:变量共享分析(Thread)
- Java多线程-变量共享分析
- Java多线程编程:变量共享分析(Thread)
- Java多线程编程:变量共享分析(Thread)
- java多线程访问同一变量及简单同步问题(待后续整理)
- java多线程范围内的共享变量
- Java 多线程 变量共享
- Java: 简单模拟多线程访问同样变量导致的问题
- Java中,对多线程访问同一变量(并发访问)的认识
- Java多线程共享全局变量问题
- java多线程:线程范围内共享变量(四)
- Java 多线程(四) 多线程访问成员变量与局部变量
- Java 多线程(四) 多线程访问成员变量与局部变量
- JAVA多线程-对象及变量的并发访问(一)synchronized详解
- 【Android应用源码分析】Java多线程:线程本地变量ThreadLocal源码分析
- Java 多线程访问成员变量与局部变量
- 多线程学习之一:线程对共享全局变量的访问
- 静态变量、实例变量、局部变量在多线程环境下的线程安全问题 java 多线程