java并发处理方式
2016-11-15 09:37
281 查看
1.用法1
某线程执行print()方法,则该对象将加锁。其它线程将无法执行该对象的所有synchronized块。
2.用法2
同用法1,但更能体现synchronized用法的本质。
3.用法3
执行print(),会给对象a加锁,注意不是给Test的对象加锁,也就是说Test对象的其它synchronized方法不会因为print()而锁,同步代码块执行完,则释放对a的锁。为了锁住一个对象的代码块而不影响该对象其它synchronized块的高性能写法。
4.静态方法的锁
效果同
Lock的使用
一个对象的lock.lock()和lock.unlock之间的代码将会被锁住,lock与synchronized的区别在于lock对wait的线程进行分类。
利用管道进行线程间通信
原理简单,两个线程,一个操作PipedInputStream,一个操作PipedOutputStream。PipedOutputStream写入的数据先缓存在Buffer中,如果Buffer满,此线程wait。PipedInputStream读出Buffer中的数据。如果Buffer没有数据,此线程wait。
阻塞队列可以代替管道流方式实现进水管/排水管。
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。
阻塞队列可以代替管道流方式实现进水管/排水管。
相关文章推荐
- java并发的处理方式
- Java中多线程并发处理方式
- java并发的处理方式
- Java 大型系统高并发大数据的处理方式
- Java 大型系统高并发大数据的处理方式
- java并发的处理方式
- java并发的处理方式
- java并发的处理方式
- java并发的处理方式
- java并发的处理方式
- Java实现高并发的处理的方式
- java并发的处理方式
- Java中多线程并发处理方式
- 在Java中使用Jedis操作Redis,在高并发的情况下,应用卡死、报无法获取连接错误的处理方式
- Java中多线程并发处理方式
- java中多线程并发的处理方式
- java并发的处理方式
- java并发的处理方式
- JAVA多线程并发处理方式
- java中的共享数据的并发处理(J2SE入门15)