java---多线程的并发控制
来源:互联网 发布:洞箫f调制作数据图 编辑:程序博客网 时间:2024/05/16 11:32
★ synchronized必须锁的是对象,基本数据类型的变量不能当作对象锁。
★ 要保证多线程使用的是同一个互斥锁(对象锁),才能进行同步。
★ 死锁的两种情况:
1)多个线程共用同一个对象锁,互相等待。
2)互相持有对方所需的资源(即每个线程都需要同时拿到多个资源才能继续执行,而多个线程都处于:各持有一部分,在等待另一部分。)
★ 死锁的解决
要从设计方面去解决避免,即在设计时就考虑不能出现死锁。
罗列出所有临界资源,画分布图,从图中观察其中的死锁情况,改变其中线程的(临界)资源的获取方式。
设计原则:尽量让程序中少出现临界资源。
'
★ wait/notify 和 sleep方法
wait和notify只能在它们被调用的实例的同步块内使用,而sleep()到处都可以用。
wait()和sleep()最大的区别:sleep()不释放对象锁,而wait()会释放,。因此从效率方面考虑wait()方法更好
★ 同步设计的基本原则
◎ 同步块中(synchronized修饰)的代码越小越好!
◎ 同步块中不要写阻塞性代码(如,InputStream.read() )!
◎ 在持有锁的时候,不要对其它对象调用方法。(如果做到,可以消除最常见的死锁源头。)
★ 同步概述
◎同步的原理:将需要同步的代码进行封装,并在该代码上加了一个锁。
◎同步的好处:解决多线程的安全问题。
◎同步的弊端:会降低性能。
◎同步的前提:必须要保证有多个线程且它们在同步中使用的是同一个锁。
0 0
- java---多线程的并发控制
- java 多线程 并发控制
- (java多线程并发)控制并发线程数的Semaphore
- Java 多线程并发控制框架
- 实现 Java 多线程并发控制框架
- 实现 Java 多线程并发控制框架
- 实现 Java 多线程并发控制框架--转载
- 实现 Java 多线程并发控制框架
- java多线程并发控制之ThreadLocal
- java多线程并发控制之锁
- 实现 Java 多线程并发控制框架
- 实现 Java 多线程并发控制框架
- 实现 Java 多线程并发控制框架
- 实现 Java 多线程并发控制框架
- java多线程并发访问问题及控制
- java多线程并发控制之ThreadLocal
- 实现 Java 多线程并发控制框架
- (java多线程并发)控制并发线程数的Semaphore、ScheduledThreadPoolExcutor、BlockingQueue、ReadWriteLock
- 总结二
- 装饰者模式
- C++第4次作业
- acm_A strange lift
- CSS3 Media Queries 与Responsive 设计
- java---多线程的并发控制
- Ubuntu 16.04 vim 报错: required vim compiled with +python
- 课程练习二-总结
- 【浅谈git常用命令】
- ZJNU 1710 dfs
- http请求和消息
- Java设计模式透析之 —— 策略(Strategy)
- Android内部File文件缓存
- HDU 2222 Keywords Search(AC自动机)