案例1: 买卖包子, 只能用于两个线程之间,当两个线程之间同时到达时Exchanger(可以类比于包子铺)
发生数据交换,否则等待:
package thread; import java.util.Random; import java.util.concurrent.Exchanger; import java.util.concurrent.TimeUnit; public class ExchangerDemo { /** * Thread-0: 卖包子。。。 Thread-1: 买包子。。。 Thread-0 : 拿到了100元钱 Thread-1 : 拿到了100个包子 */ public static void main(String[] args) { final Exchanger<String> exchanger = new Exchanger<String>(); new Thread(new Runnable() { @Override public void run() { System.out.println(Thread.currentThread().getName() + ": 卖包子。。。"); try { TimeUnit.SECONDS.sleep(new Random().nextInt(5)); String data1 = "100个包子"; String result = exchanger.exchange(data1); System.out.println(Thread.currentThread().getName()+ " : 拿到了" + result); } catch (InterruptedException e) { e.printStackTrace(); } } }).start(); new Thread(new Runnable() { @Override public void run() { System.out.println(Thread.currentThread().getName() + ": 买包子。。。"); try { TimeUnit.SECONDS.sleep(new Random().nextInt(5)); String data1 = "100元钱"; String result = exchanger.exchange(data1); System.out.println(Thread.currentThread().getName()+ " : 拿到了" + result); } catch (InterruptedException e) { e.printStackTrace(); } } }).start(); } }
package cn.itcast.heima2; import java.util.concurrent.Exchanger; import java.util.concurrent.ExecutorService; import java.util.concurrent.Executors; /** 线程pool-1-thread-1正在把数据hello换出去 线程pool-1-thread-2正在把数据future换出去 线程pool-1-thread-1换回的数据为future 线程pool-1-thread-2换回的数据为hello 第一个拿出数据的人将一直等到第二个人拿到数据到来时,才彼此交换数据。 * @author zm * */ 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 = "hello"; System.out.println("线程" + Thread.currentThread().getName() + "正在把数据" + data1 +"换出去"); Thread.sleep((long)(Math.random()*10000));// 真实中需要替换成业务, 业务有耗时操作 这里使用沉睡来模拟 String data2 = (String)exchanger.exchange(data1);// 操作完上一行业务后, 甲将自己数据hello 和 乙做交换 System.out.println("线程" + Thread.currentThread().getName() + "换回的数据为" + data2); }catch(Exception e){ } } }); service.execute(new Runnable(){ public void run() { try { String data1 = "future"; System.out.println("线程" + Thread.currentThread().getName() + "正在把数据" + data1 +"换出去"); Thread.sleep((long)(Math.random()*10000)); String data2 = (String)exchanger.exchange(data1);// 操作完上一行业务后, 乙将自己数据future 和 甲做交换, 当最终那个最慢的人也将数据拿出来后,交换完毕,双方分到需要的数据 System.out.println("线程" + Thread.currentThread().getName() + "换回的数据为" + data2); }catch(Exception e){ } } }); } }
相关推荐
包含 jdk1.5免安装、jdk1.6免安装、jdk1.8(32和64)
jdk1.5.exe jdk1.5 jdk1.5下载
前几天上传过这个资源,因为是在jdk1.6上开发的, 测试了一下在jdk1.5上不能用, 今天重新用jdk1.5编译了一下, 这个是可以支持jdk1.5+的 将 pu-xlscommon-1.0.0.jar 添加到工程的 /lib 目录下 用法在附件中 XlsTest....
JDK1.5,JDK1.5
绝版jdk1.5,非常不错的资源。用起来很好。是 Java语言对Bean类属性、事件的一种缺省处理方法。例如类A中有属性name,那我们可以通过getName,setName来得到其值或者设置新 的值。通过getName/setName来访问name属性,...
测试可用的linux版jdk1.5,jdk-1_5_0_19-linux-i586-rpm.bin
jdk1.5.0.22 是jdk1.5的最后一版,jdk1.5 windows 64位官方正式版,绝对有效,jdk1.5 windows 64位官方正式版,绝对有效
jdk 1.5 中文 api chm jdk 1.5 中文 api chm
很实用的JAVA API中文参考文档,如果你开始讨厌HTML版本的API中文文档,试试这个吧,强大的索引功能使你开发更加愉快,分两卷,要都下了才能解压。
jdk1.5.0.22 是jdk1.5的最后一版
“JDK1.5”(开发代号猛虎)的一个重要主题就是通过新增一些特性来简化开发,这些特性包括泛型,for-else 循环,自动装包/拆包,枚举,可变参数, 静态导入
JDK1.5 API完整版JDK1.5 API完整版JDK1.5 API完整版
JDK1.5+1.6整合版(文件为txt文件,里面有百度网盘下载地址<文件太大所以用网盘>) 文件里含有1.5和1.6两个版本的JDK,并且附有一环境变量创建办法以及切换版本方法
Jdk1.5Doc_CN.chm Jdk1.5Doc_CN.chm Jdk1.5Doc_CN.chm Jdk1.5Doc_CN.chm
详细介绍java对象的使用和说明详细介绍java对象的使用和说明详细介绍java对象的使用和说明详细介绍java对象的使用和说明详细介绍java对象的使用和说明
jdk1.5 64位 windows版
jdk1.5压缩包 解压缩可用 用于Windows系统
Java-jdk1.5安装包
转载 jdk1.5的一些新特性,希望能帮助大家!
jdk1.5api,方便搜索版,不解释,谁用谁知道