并发编程回顾:线程数据交换器Exchanger

原先多线程并发编程的学习笔记和代码整理一下贴上来。

---------------------------------

线程数据交换器Exchanger

根据JDK文档描述:

可以在对中对元素进行配对和交换的线程的同步点。每个线程将条目上的某个方法呈现给 exchange 方法,与伙伴线程进行匹配,并且在返回时接收其伙伴的对象。Exchanger 可能被视为 SynchronousQueue 的双向形式。Exchanger 可能在应用程序(比如遗传算法和管道设计)中很有用。

举一个非常简单的例子:

定义2个线程,以及一个exchanger交换器,该交换器交换String类型的数据。

final Exchanger<String> changer = new Exchanger<String>();
new Thread(new Runnable() {
			public void run() {
				try {
					Thread.sleep(new Random().nextInt(5000));
					String data1 = "data1";
					String data2 = changer.exchange(data1);
					System.out.println("thread1 get return data is " + data2);
				} catch (Exception e) {
					e.printStackTrace();
				}
			}
}).start();
		
new Thread(new Runnable() {
			public void run() {
				try {
					Thread.sleep(new Random().nextInt(5000));
					String data1 = "data2";
					String data2 = changer.exchange(data1);
					System.out.println("thread2 get return data is " + data2);
				} catch (Exception e) {
					e.printStackTrace();
				}
			}
}).start();

如上,两个线程启动后会睡眠一段时间,然后到达交换点。

关于exchange()方法:

等待另一个线程到达此交换点(除非当前线程被中断),然后将给定的对象传送给该线程,并接收该线程的对象。

也就是说如果另一个线程没有到达交换点,则会阻塞。

运行程序,结果为2个string数据交换:

thread1 get return data is data2
thread2 get return data is data1

全文完。

你可能感兴趣的:(Exchanger)