java解决线程不安全问题的方法
来源:互联网 发布:nosql数据库有哪些 编辑:程序博客网 时间:2024/05/21 03:24
线程不安全问题
当多线程并发访问同一个资源时,容易出现不安全问题 有时候我们分析打印结果,发现没有问题,但是并不是真的没问题,可能我们经验不够,没有发现问题。为了放大问题是用Thread中的sleep()方法
Thread.sleep(100); //是当前线程睡眠100毫秒,让其他线程去抢资源,经常用来模拟网络延迟。放大线程中的问题。
解决方法:
(1)同步代码块
(2)同步方法
(3)锁机制(Lock)
1.同步代码块
synchronized( 同步锁){ //同步锁:同步监听对象/ 同步监听器 /互斥锁
需要同步操作的代码
}
对象的同步锁只是一个概念,可以想象在对象上标记 一个锁
java程序运行可以使用任何对象作为同步监听对象,但是一般我们将当前i并发访问的共同资源(多个线程同步共享的资源对象)作为同步监听对象。
注意:在任何时候,只允许一个线程拥有同步锁,谁拿到锁就进入代码块,其他线程只能在外面等
2.同步方法
使用synchronized修饰的方法叫做同步方法,保证该线程执行该方法的时候,其他线程只能等着。
同步锁:1.非static方法,同步锁是this。2.static方法,使用当前方法所在类的字节码对象(Apple.class)是同步锁
注意:
synchronized不能修饰run方法,修饰之后,一个线程就执行了所有的功能,线程出现串行,相当于单线程。
解决方法:将需要同步的 代码定义在一个新的方法中,并且该方法用synchronized修饰,再在run方法中调用该新的方法即可
synchronized提高安全性,但是性能降低了,使用时尽量减小它的作用域。eg:stringBuffer和StringBuilder的区别,stringBuffer的方法全都加了synchronized修饰。
类似的还有:ArrayList和vector HashMap和Hashtable 一般选择使用性能比较高的。
**单例模式-懒加载同步
结论:单例模式使用 饿汉式;简单粗暴。
3.锁机制(Lock)
Lock是一个接口,实现提供更广泛的锁定操作可以比使用synchronized获得方法和报表。
锁是一种通过多个线程控制对共享资源的访问的工具。通常,一个锁提供对共享资源的独占访问:在一个时间只有一个线程可以获得锁和所有访问共享资源,需要先获得锁。
- java解决线程不安全问题的方法
- 解决SimpleDateFormat的线程不安全问题的方法:ThreadLocal
- java中如何解决线程不安全的问题呢?
- java中同步synchronized的意义,如何用它解决线程不安全的问题
- 线程同步:解决线程不安全问题
- 解决多线程单例模式的线程不安全问题
- java线程冲突问题——不安全的线程例子
- ArrayList的线程不安全问题
- java--线程不安全的类
- Java SimpleDateFormat 线程不安全问题及解决方法
- 解决ArrayList线程不安全
- 解决ArrayList线程不安全
- 解决ArrayList线程不安全
- 解决ArrayList线程不安全
- 线程、线程匿名内部类、解决线程不安全的方式
- 解决安全扫描HTTP的不安全方法
- java的线程安全与不安全
- VS2013解决映像不安全的问题
- POJ 3090 Visible Lattice Points 笔记
- 访问权限修饰符
- 《剑指offer》笔记-第三章(4)
- 分区
- 《探索Android热修复技术原理》总结
- java解决线程不安全问题的方法
- 九度 1088
- 什么是模块化开发?
- 二分图最大匹配
- 纯属无聊玩贪心
- java学习之路(1)-第一个hello word
- 设计模式——抽象工厂模式
- Dubbo中的协议
- centos6.5 yum安装mysql5.7