java并发处理方式
来源:互联网 发布:装修公司 施工队 知乎 编辑:程序博客网 时间:2024/05/20 11:26
1.用法1
public class Test{ public synchronized void print(){ ....; }}
某线程执行print()方法,则该对象将加锁。其它线程将无法执行该对象的所有synchronized块。
2.用法2
public class Test{ public void print(){ synchronized(this){ ....; } }}
同用法1,但更能体现synchronized用法的本质。
3.用法3
public class Test{ private String a="test"; public void print(){ synchronized(a){ ...; } } public synchronized void t(){ ...; }}
执行print(),会给对象a加锁,注意不是给Test的对象加锁,也就是说Test对象的其它synchronized方法不会因为print()而锁,同步代码块执行完,则释放对a的锁。为了锁住一个对象的代码块而不影响该对象其它synchronized块的高性能写法。
4.静态方法的锁
public class Test{ public synchronized static void execute(){ ...; }}
public class Test{ public static void execute(){ synchronized(TestThread.class){ ...; } }}
Lock的使用
一个对象的lock.lock()和lock.unlock之间的代码将会被锁住,lock与synchronized的区别在于lock对wait的线程进行分类。
LockawaitsignalsignalAllsynchronizedwaitnotifynotifyAll利用管道进行线程间通信
原理简单,两个线程,一个操作PipedInputStream,一个操作PipedOutputStream。PipedOutputStream写入的数据先缓存在Buffer中,如果Buffer满,此线程wait。PipedInputStream读出Buffer中的数据。如果Buffer没有数据,此线程wait。
阻塞队列可以代替管道流方式实现进水管/排水管。
0 0
- java并发处理方式
- java并发的处理方式
- java并发的处理方式
- java并发的处理方式
- java并发的处理方式
- java并发的处理方式
- java并发的处理方式
- java并发的处理方式
- java并发的处理方式
- JAVA多线程并发处理方式
- java并发的处理方式
- java并发的处理方式
- Java中多线程并发处理方式
- java中多线程并发的处理方式
- Java中多线程并发处理方式
- Java 大型系统高并发大数据的处理方式
- Java 大型系统高并发大数据的处理方式
- Java实现高并发的处理的方式
- IT十八掌将在csdn学院进行线上合作
- Java超级基础
- Qt SVG Viewer
- html 简单select样式修改并兼容IE浏览器
- Extjs4学习总结之combox组件
- java并发处理方式
- 解决Android启动显示空白界面的问题
- NOIP2015运输计划
- 浅析python 中__name__ = '__main__' 的作用
- HDU 1166 敌兵布阵
- iOS开发系列--视图切换
- lsmod modinfo ....
- 【ES6学习】— (7)Set、Map数据结构与Iterator遍历器
- 【Redis缓存机制】1.Redis介绍和使用场景