JAVA并发编程的理解
来源:互联网 发布:windows下wget命令 编辑:程序博客网 时间:2024/06/01 07:33
并发编程时,必须考虑安全性问题,即线程安全,所谓线程安全就是可以同时被多个线程调用,调用者无须额外的操作,程序也不会出现错误的结果。 要使程序是线程安全的,必须考虑以下2点:
- 是否存在竞态条件,常见的是那些先检查后执行的操作行为,它的正确结果取决于运气。避免错误结果的方法是保证操作的原子性,通常使用加锁,也有一些原子变量类可以达到目的。
- 对象状态在内存中是否可见,即当一个线程修改了对象的状态后,其他线程不一定看到修改后的状态。保证其他线程总是能看到最新状态的方法有2种:一种是加锁,另一种是使用volatile变量。
于是得出几个结论:
- 加锁机制可保证可见性和原子性,所以能保证线程安全;
- 原子变量可保证原子性,但不能保证可见性,所以不能保证线程安全;
- volatile变量能保证可见性,但不能保证原子性,所以不能保证线程安全;
- volatile的原子变量能保证线程安全。
除此之外,还有一些对象一定是线程安全的:
- 无状态对象;
- 不可变对象。
但是加锁机制会产生活跃性问题,活跃性问题关注正确的行为是否一定会发生,主要有死锁问题。
死锁简单来讲是这样的:线程A持有锁L并想获得锁M,同时线程B持有锁M并想获得锁L,这时线程A和B都永久阻塞。
避免死锁的关键是要保证每个线程获取锁的顺序必须相同,如上面线程A和B获取锁的顺序如果都是先获取锁L再获取锁M,就不会发生死锁问题。
当持有锁时调用外部方法,会很难分析获取锁的顺序,要尽量避免。
编码参考:
- 将所有可变状态都封装在对象内部,并通过对象的内置锁对所有访问可变状态的代码进行同步;
- 扩展线程安全的容器类时,在新类中委托容器类的其他方法,使用新锁,不要关心原来的容器类是否线程安全。
参考资料: 《JAVA并发编程实战》
微信订阅号:
源文地址:http://blog.gopersist.com/2014/10/10/java-concurrent/
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多线程与并发编程
- 小菜鸟对并发编程的理解
- 小猴子下落
- linux下安装mysql数据库
- Linux内核分析-计算机汇编程序分析
- java值传递与引用传递
- 公司绝不会告诉你的10大秘密
- JAVA并发编程的理解
- XMPP开发之文字聊天
- viewpager轮播图点的切换
- 犀牛——第19章jquery类库 19.6 JQuery中的Ajax
- Linux Shell编程入门
- How to find the ABAP examples
- 工欲善其事必先利其器——MyEclipse的设置
- rs.Open sql,conn的不同方式
- Eclipse常用快捷键大全