Java线程同步阻塞队列LinkedTransferQueue

44 篇文章 7 订阅
19 篇文章 0 订阅

Java线程同步阻塞队列LinkedTransferQueue

import java.util.concurrent.LinkedTransferQueue;
import java.util.concurrent.TimeUnit;

/**
 * Java线程同步阻塞队列LinkedTransferQueue
 *
 * Java LinkedTransferQueue是SynchronousQueue的升级。
 * LinkedTransferQueue是一个链表结构的无界阻塞TransferQueue队列。
 * 当消费者取数据时,如果队列非空,则直接取出数据(队列变空)。
 * 当消费者取数据时,如果队列为空,那么就生成一个节点(节点为null)入队,然后消费者线程被等待在这个节点上,等待生产者线程把数据制造出来。
 */
public class Main {
    private LinkedTransferQueue<String> mQueue;

    public static void main(String[] args) {
        try {
            new Main().test();
        } catch (Exception e) {
            e.printStackTrace();
        }
    }

    private void test() {
        mQueue = new LinkedTransferQueue();

        //生产者和消费者在线程并发的竞争环境下对队列数据进行读写。
        consumer();
        producer();
    }

    /**
     * 数据生产者。
     */
    private void producer() {
        new Thread(new Runnable() {
            @Override
            public void run() {
                while (true) {
                    try {
                        TimeUnit.SECONDS.sleep(3);
                    } catch (InterruptedException e) {
                        e.printStackTrace();
                    }

                    //生成一个数据元素放到队列中。
                    try {
                        mQueue.transfer(System.currentTimeMillis() + ""); //.add()或者addAll()
                    } catch (Exception e) {
                        e.printStackTrace();
                    }
                }
            }
        }).start();
    }

    /**
     * 数据消费者。
     */
    private void consumer() {
        new Thread(new Runnable() {
            @Override
            public void run() {
                while (true) {
                    try {
                        //消费,取走一个数据元素。
                        String s = mQueue.take();

                        System.out.println(s);
                    } catch (Exception e) {
                        e.printStackTrace();
                    }
                }
            }
        }).start();
    }
}

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

zhangphil

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值