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的线程进行分类。
Lock | await | signal | signalAll |
synchronized | wait | notify | notifyAll |
利用管道进行线程间通信
原理简单,两个线程,一个操作PipedInputStream,一个操作PipedOutputStream。PipedOutputStream写入的数据先缓存在Buffer中,如果Buffer满,此线程wait。PipedInputStream读出Buffer中的数据。如果Buffer没有数据,此线程wait。
阻塞队列可以代替管道流方式实现进水管/排水管。
最后欢迎大家访问我的个人网站:1024s