Java线程之Exchanger-兄弟线程的信息交换
2014-02-12 13:49
387 查看
如果两个线程在运行过程中需要交换彼此的信息,比如一个数据或者使用的空间,就需要用到Exchanger这个类,Exchanger为线程交换信息提供了非常方便的途径,它可以作为两个线程交换对象的同步点,只有当每个线程都在进入 exchange ()方法并给出对象时,才能接受其他线程返回时给出的对象。
Exchanger的构造方法如下:
[java]
Exchanger(); //创建一个新的 Exchanger。
Exchanger用到的主要方法有:
[java]
exchange(V x); //等待另一个线程到达此交换点(除非它被中断),然后将给定的对象传送给该线程,并接收该线程的对象。
exchange(V x, long timeout, TimeUnit unit); // 等待另一个线程到达此交换点(除非它被中断,或者超出了指定的等待时间),然后将给定的对象传送给该线程,同时接收该线程的对象。
下面通过例子来加以说明:
[java]
public class ExchangerTest {
public static void main(String[] args) {
ExecutorService service = Executors.newCachedThreadPool();
final Exchanger exchanger = new Exchanger();
service.execute(new Runnable(){
public void run() {
try {
String data1 = "zxx";
System.out.println("线程" + Thread.currentThread().getName() +
"正在把数据" + data1 +"换出去");
Thread.sleep((long)(Math.random()*10000));
String data2 = (String)exchanger.exchange(data1);
System.out.println("线程" + Thread.currentThread().getName() +
"换回的数据为" + data2);
}catch(Exception e){
}
}
});
service.execute(new Runnable(){
public void run() {
try {
String data1 = "lhm";
System.out.println("线程" + Thread.currentThread().getName() +
"正在把数据" + data1 +"换出去");
Thread.sleep((long)(Math.random()*10000));
String data2 = (String)exchanger.exchange(data1);
System.out.println("线程" + Thread.currentThread().getName() +
"换回的数据为" + data2);
}catch(Exception e){
}
}
});
}
}
上例main()方法中创建了2个线程,两个线程都有各自String类型的data,并且各自的sleep时间都不一样。类中定义了一个Exchanger对象,作为两个线程交换数据的通道,当其中一个线程运行exchanger.exchange();方法时,由于没有另外一个线程还没有开始执行这个交换方法,所以就需要等到另外一个线程也提出交换时,两个线程才可以完成信息的交换。其运行结果如下:
[java]
线程pool-1-thread-1正在把数据zxx换出去
线程pool-1-thread-2正在把数据lhm换出去
线程pool-1-thread-2换回的数据为zxx
线程pool-1-thread-1换回的数据为lhm
Exchanger的构造方法如下:
[java]
Exchanger(); //创建一个新的 Exchanger。
Exchanger用到的主要方法有:
[java]
exchange(V x); //等待另一个线程到达此交换点(除非它被中断),然后将给定的对象传送给该线程,并接收该线程的对象。
exchange(V x, long timeout, TimeUnit unit); // 等待另一个线程到达此交换点(除非它被中断,或者超出了指定的等待时间),然后将给定的对象传送给该线程,同时接收该线程的对象。
下面通过例子来加以说明:
[java]
public class ExchangerTest {
public static void main(String[] args) {
ExecutorService service = Executors.newCachedThreadPool();
final Exchanger exchanger = new Exchanger();
service.execute(new Runnable(){
public void run() {
try {
String data1 = "zxx";
System.out.println("线程" + Thread.currentThread().getName() +
"正在把数据" + data1 +"换出去");
Thread.sleep((long)(Math.random()*10000));
String data2 = (String)exchanger.exchange(data1);
System.out.println("线程" + Thread.currentThread().getName() +
"换回的数据为" + data2);
}catch(Exception e){
}
}
});
service.execute(new Runnable(){
public void run() {
try {
String data1 = "lhm";
System.out.println("线程" + Thread.currentThread().getName() +
"正在把数据" + data1 +"换出去");
Thread.sleep((long)(Math.random()*10000));
String data2 = (String)exchanger.exchange(data1);
System.out.println("线程" + Thread.currentThread().getName() +
"换回的数据为" + data2);
}catch(Exception e){
}
}
});
}
}
上例main()方法中创建了2个线程,两个线程都有各自String类型的data,并且各自的sleep时间都不一样。类中定义了一个Exchanger对象,作为两个线程交换数据的通道,当其中一个线程运行exchanger.exchange();方法时,由于没有另外一个线程还没有开始执行这个交换方法,所以就需要等到另外一个线程也提出交换时,两个线程才可以完成信息的交换。其运行结果如下:
[java]
线程pool-1-thread-1正在把数据zxx换出去
线程pool-1-thread-2正在把数据lhm换出去
线程pool-1-thread-2换回的数据为zxx
线程pool-1-thread-1换回的数据为lhm
相关文章推荐
- Java线程(十二):Exchanger-兄弟线程的信息交换
- Exchanger-兄弟线程的信息交换
- Exchanger兄弟线程间数据信息交换
- Java线程(十二):Exchanger-兄弟线程的信息交换
- java 线程间交换数据的Exchanger
- java学习——使用Exchanger实现两个线程间的数据交换
- Exchanger——Java两个线程间交换数据的工具类
- java的Exchanger 两个线程可以交换对象Demo
- Java多线程与并发库高级应用之线程数据交换Exchanger
- Java并发工具类(四):线程间交换数据的Exchanger
- java多线程-Thread两个线程交换数据Exchanger
- 13____java线程同步工具类之线程数据交换(Exchanger)
- Java Exchanger(两线程交换数据)
- Java多线程/并发25、Exchanger线程数据交换
- JAVA线程同步辅助类Exchanger-交换
- Java并发工具类之线程间数据交换工具Exchanger
- Java高级篇(四十五)------Java线程之Exchanger
- Exchanger:线程交换数据
- java5 Exchanger数据交换
- Java并发库(十七):线程交换Exchanger