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

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

阻塞双端消息队列 BlockingDeque(先进先出的原则管理)_第1张图片
看图我们之后秒懂了吧,当我们需要把数据发送的对方时,又想有规律均速一条一条的发送,我们就可以这么干了。

直接上菜啦:
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);
                }
            }
        }
    }

你可能感兴趣的:(移动开发-Android)