【Java并发】Java内存模型和线程安全
来源:互联网 发布:linux 脚本 关闭程序 编辑:程序博客网 时间:2024/05/18 02:24
Java内存模型
1、原子性
指一个操作是不可中断的,即使实在多个线程一起执行的时候,一个操作一旦开始,就不会被其它线程干扰。
i++是原子操作吗?
答案是否定的,两个线程对i++进行操作,线程1读到i++为2,线程2也进行操作读到i++为2,最终i=2,但是两个线程同时对i++进行操作,i应该为3的,所以i++并不是原子操作,不满足原子特性。
2、有序性:
程序实际执行的顺序和你实际书写的顺序未必是一样的。
一条指令的执行是可以分为很多步骤的
–取指 IF
–译码和取寄存器操作数 ID
–执行或者有效地址计算 EX
–存储器访问 MEM
–写回 WB
3、可见性:
当一个线程修改了某一个共享变量的值,其他线程是否能够立刻指导这个修改。
编译器优化
硬件优化,如批操作
4、Happen-Before
程序顺序原则:一个线程内保证语义的串行性
volatile规则:volatile变量的写,先发生于读,这保证了volatile变量的可见性
锁规则:解锁(unlock)必然发生在随后的加锁(lock)前
传递性:A先于B,B先于C,那么A必然先于C
线程的start()方法先于它的每一个动作
线程的所有操作先于线程的终结(Thread.join())
线程的中断(interrupt())先于被中断线程的代码
对象的构造函数执行结束先于finalize()方法
线程安全
指某个函数、函数库在多线程环境中被调用时,能够正确地处理各个线程的局部变量,使程序功能正确完成。
i++在多线程下访问的情况:
代码:
public class AccountingSync implements Runnable{ static AccountingSync instance=new AccountingSync(); static int i=0; @Override public void run() { for(int j=0;j<10000000;j++){ synchronized(instance){ i++; } } }
阅读全文
1 0
- [高并发Java 三] Java内存模型和线程安全
- 【高并发Java三】Java内存模型和线程安全
- 高并发Java 三 Java内存模型和线程安全
- 高并发Java 三 Java内存模型和线程安全
- 【Java并发】Java内存模型和线程安全
- 高效并发-Java内存模型和线程
- 【转载】JAVA内存模型和线程安全
- Java内存模型和线程安全
- JAVA内存模型和线程安全
- JAVA内存模型和线程安全
- 高并发Java(3):Java内存模型和线程安全
- JAVA并发编程2_线程安全&内存模型
- 【并发编程】从Java内存模型看并发数据共享与线程安全
- 线程安全与并发编程探究(七)--volatile java内存模型及线程知识小结
- 【并发】java线程内存模型,线程、工作内存、主内存
- Java内存模型以及线程安全
- 从Java内存模型的角度思考线程安全与并发
- java并发编程(二内存模型、线程安全、无锁)
- android错误No Activity found to handle Intent
- python小程序-0002
- redis入门指南中命令总结
- [Android6.0][RK3399] PCIe 接口 4G模块 EC20 调试记录
- leetcode 383. Ransom Note
- 【Java并发】Java内存模型和线程安全
- hql语句:单表查询
- Oracle 大小写区分的处理
- python基础
- Entity Framework Code First实体关联数据加载
- HTML&CSS基础篇之三:HTML基础结构之ML篇
- HTML5之svg(如何绘制图型)
- maven中的groupid和artifactid
- HAWQ + MADlib 玩转数据挖掘之(一)——安装