阻塞双端消息队列 BlockingDeque(先进先出的原则管理)

昨晚为了赶项目,干到两点钟,不过也有收获,来自华为的大神,在我们公司做后台,教了我一招好用的消息队列管理方法,分享给大家了。
既是一个队列的生产者又是这个队列的消费者的时候可以使用到 BlockingDeque。

这里写图片描述
看图我们之后秒懂了吧,当我们需要把数据发送的对方时,又想有规律均速一条一条的发送,我们就可以这么干了。

直接上菜啦:
1. 现在onCreate中启动消息处理器


        new HandleMess().start();

2 获得BlockingDeque对象

 BlockingDeque<byte[]>  queueBlockingDeque = new LinkedBlockingDeque<byte[]>();

3.现在所有的数据都添加到BlockingDepue对象中。以先进先出的原则管理消息队列


    public  void sendMessage(final byte[] message) {
        queueBlockingDeque.addLast(message);

    }

4.通过BlockingDeque对象,以先进先出的原则来管理消息的发送

private class HandleMess  extends Thread {

        @Override
        public void run() {
            while (true) {
                try {
                    //获得要发送的消息,每次获取一条(重点)
                    byte[] message = queueBlockingDeque.poll();

                    if (message == null) {
                        Thread.sleep(500);
                        continue;
                    }
                    // 检查是否有东西送
                    if (message.length > 0 ) {                                          
                    mLockService.write(message);//发送                                                                                    
                     Thread.sleep(800);                     
                        } else {
                            Thread.sleep(1000);
                            continue;
                        }                   
                    }
                } catch (Exception e) {
                     Log.e("wrh", "发送消息异常", e);
                }
            }
        }
    }
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值