您的位置:首页 > 产品设计 > UI/UE

thread41 - LinkedTransferQueue

2017-06-16 16:07 225 查看
package com.neutron.t22;

import java.util.concurrent.LinkedTransferQueue;

/**
*  LinkedTransferQueue
*  使用场景消费者线程先启动,生产者去生产首先找有没有消费者,如果有消费者就不扔到队列,直接给消费者
*
*  比如玩棋牌类游戏,a发牌后需要通知bcd,那么消息可以发送到队列中,然后通过队列发给bcd,也可以通过LinkedTransferQueue
*  如果有消息消费者,直接发给消费者线程即可,而不走消息队列,效率会更加高,支持并发会更高更好
*
*/
public class T228LinkedTransferQueue {
static LinkedTransferQueue<String> queue = new LinkedTransferQueue<>();

/**
* 如果单独执行m1方法,那么执行到transfer会阻塞,后面的消费者线程不会启动
*/
static void m1() throws InterruptedException {
// 如果开始没有找到消费者线程,那么使用transfer会阻塞
queue.transfer("hello");
// 如果使用add、offer、put都不会存在阻塞问题

// 消费者线程启动
new Thread(() -> {
try {
System.out.println(queue.take());
} catch (InterruptedException e) {
e.printStackTrace();
}
}, "client").start();
}

/**
* 如果单独执行m2方法,正常执行
* 先启动消费者线程,那么LinkedTransferQueue会先去找是否有消费者线程,有消费者线程继续执行
*/
static void m2() throws InterruptedException {
// 消费者线程启动
new Thread(() -> {
try {
System.out.println(queue.take());
} catch (InterruptedException e) {
e.printStackTrace();
}
}, "client").start();

// 如果开始没有找到消费者线程,那么使用transfer会阻塞
queue.transfer("hello");
}

/**
* 注意单独启动m1和m2方法的执行结果
* m2是有效的正常写法,打印出来hello
*/
public static void main(String[] args) throws InterruptedException {
// m1();
m2();
}

}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: