JAVA并发编程的理解
来源:互联网 发布:快速阅读记忆训练软件 编辑:程序博客网 时间:2024/06/05 21:11
并发编程时,必须考虑安全性问题,即线程安全,所谓线程安全就是可以同时被多个线程调用,调用者无须额外的操作,程序也不会出现错误的结果。
要使程序是线程安全的,必须考虑以下2点:
- 是否存在竞态条件,常见的是那些先检查后执行的操作行为,它的正确结果取决于运气。避免错误结果的方法是保证操作的原子性,通常使用加锁,也有一些原子变量类可以达到目的。
- 对象状态在内存中是否可见,即当一个线程修改了对象的状态后,其他线程不一定看到修改后的状态。保证其他线程总是能看到最新状态的方法有2种:一种是加锁,另一种是使用volatile变量。
于是得出几个结论:
- 加锁机制可保证可见性和原子性,所以能保证线程安全;
- 原子变量可保证原子性,但不能保证可见性,所以不能保证线程安全;
- volatile变量能保证可见性,但不能保证原子性,所以不能保证线程安全;
- volatile的原子变量能保证线程安全。
除此之外,还有一些对象一定是线程安全的:
- 无状态对象;
- 不可变对象。
但是加锁机制会产生活跃性问题,活跃性问题关注正确的行为是否一定会发生,主要有死锁问题。
死锁简单来讲是这样的:线程A持有锁L并想获得锁M,同时线程B持有锁M并想获得锁L,这时线程A和B都永久阻塞。
死锁简单来讲是这样的:线程A持有锁L并想获得锁M,同时线程B持有锁M并想获得锁L,这时线程A和B都永久阻塞。
避免死锁的关键是要保证每个线程获取锁的顺序必须相同,如上面线程A和B获取锁的顺序如果都是先获取锁L再获取锁M,就不会发生死锁问题。
当持有锁时调用外部方法,会很难分析获取锁的顺序,要尽量避免。
编码参考:
- 将所有可变状态都封装在对象内部,并通过对象的内置锁对所有访问可变状态的代码进行同步;
- 扩展线程安全的容器类时,在新类中委托容器类的其他方法,使用新锁,不要关心原来的容器类是否线程安全。
参考资料:
《JAVA并发编程实战》
0 0
- JAVA并发编程的理解
- JAVA并发编程的理解
- 对JAVA多线程 并发编程的理解
- 对JAVA多线程 并发编程的理解
- Java并发编程之volatile的理解
- Java并发编程之volatile关键字的理解
- Java并发编程之线程池的理解与使用
- Java并发编程之volatile关键字的理解与使用
- 谈谈我对Java并发的理解——读《Java并发编程实战有感》
- 理解高并发(2).我对并发编程的理解
- 深入理解java虚拟机【并发编程缓存】
- 深入理解java虚拟机【并发编程缓存】
- (转)java并发编程: 彻底理解ThreadLocal
- java并发编程中的一些理解
- Java并发编程--深入理解Semaphore
- Java并发编程--深入理解volatile关键字
- 深入理解Java多线程与并发编程
- 小菜鸟对并发编程的理解
- 使用Spring的classutil类体验
- Loopback测试软件AX1用户手册 V3.1
- 《设计师要懂心理学》之读书笔记
- jquery的each()详细介绍
- Android 中多点触摸协议
- JAVA并发编程的理解
- cgi怎么获取页面请求参数(get、post两种请求)
- iOS8 UIAlertController 弹框
- LeetCode Single Number
- docker粗浅理解
- 【Stackoverflow好问题】获取完整的堆栈信息
- 第七周项目3
- AchartEngine 在多条折现更新时 出现数组越界问题的原因
- iOS 调试工具方法