thread41 - LinkedTransferQueue

本文深入探讨了Java并发包中LinkedTransferQueue的特点与应用场景,特别是针对消费者线程先启动的情况进行了详细解析。通过对比transfer与其他队列操作方法的区别,强调了其在提高并发效率方面的优势。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

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();
    }

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值