Java并发工具类Exchanger的相关知识总结
程序员文章站
2022-03-10 17:01:08
一、exchanger的理解 exchanger 属于java.util.concurrent包; exchanger 是 jdk 1.5 开始提供的一个用于两个工作线程之间交换数据的封装...
一、exchanger的理解
- exchanger 属于java.util.concurrent包;
- exchanger 是 jdk 1.5 开始提供的一个用于两个工作线程之间交换数据的封装工具类;
- 一个线程在完成一定的事务后想与另一个线程交换数据,则第一个先拿出数据的线程会一直等待第二个线程,直到第二个线程拿着数据到来时才能彼此交换对应数据。
二、exchanger类中常用方法
- public exchanger() 无参构造方法。表示创建一个新的交换器。
-
public v exchange(v x) 等待另一个线程到达此交换点(除非当前线程为 interrupted ),然后将给定对象传输给它,接收其对象作为回报。
(1)、x :表示可以交换的对象
-
public v exchange(v x, long timeout, timeunit unit) 等待另一个线程到达此交换点(除非当前线程为 interrupted或指定的等待时间已过),然后将给定对象传输给它,接收其对象作为回报。
(1)、 x :交换对象
(2)、timeout :等待的最长时间
(3)、unit :timeout参数的时间单位
三、exchanger类的使用示例
案例场景
模拟客户端和服务端交换数据。
1、代码
package com.xz.thread.exchanger; import java.util.concurrent.exchanger; /** * @description: * @author: xz * @create: 2021-05-31 21:56 */ public class demo { //定义一个服务端方法 public void servermethod(exchanger<string> exchanger){ system.out.println("【服务端】方法开始执行"); //睡眠1秒钟 try { thread.sleep(1000); } catch (interruptedexception e) { e.printstacktrace(); } //定义服务端数据 string data="serverdata"; //等待另一个线程到达此交换点(除非当前线程为interrupted),然后将给定对象传输给它,接收其对象作为回报。 string exchangedata=""; try { exchangedata=exchanger.exchange(data); } catch (interruptedexception e) { e.printstacktrace(); } system.out.println("服务端原数据="+"serverdata,"+" 交换后的数据=" + exchangedata); } //定义一个客户端方法 public void clientmethod(exchanger<string> exchanger){ system.out.println("【客户端】方法开始执行"); //睡眠3秒钟 try { thread.sleep(3000); } catch (interruptedexception e) { e.printstacktrace(); } //定义客户端数据 string data="clientdata"; //等待另一个线程到达此交换点(除非当前线程为interrupted),然后将给定对象传输给它,接收其对象作为回报。 string exchangedata=""; try{ exchangedata =exchanger.exchange(data); } catch (interruptedexception e) { e.printstacktrace(); } system.out.println("客户端原数据="+"clientdata, "+"交换后的数据=" + exchangedata); } //测试类 public static void main(string[] args) { demo d =new demo(); //实例化exchanger exchanger<string> exchanger =new exchanger(); //第一个线程 new thread(new runnable() { @override public void run() { d.servermethod(exchanger); } }).start(); //第二个线程 new thread(new runnable() { @override public void run() { d.clientmethod(exchanger); } }).start(); } }
2、运行main函数,输出结果如下:
到此这篇关于java并发工具类exchanger的相关知识总结的文章就介绍到这了,更多相关java工具类exchanger内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!
上一篇: Java多线程之线程状态的迁移详解
下一篇: 详解JVM系列之对象的锁状态和同步