第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

為了賬號(hào)安全,請(qǐng)及時(shí)綁定郵箱和手機(jī)立即綁定
已解決430363個(gè)問(wèn)題,去搜搜看,總會(huì)有你想問(wèn)的

Android BLE 寫(xiě)入特性鎖定 onCharacteristicWrite/

Android BLE 寫(xiě)入特性鎖定 onCharacteristicWrite/

大話西游666 2023-10-13 14:53:42
我有一個(gè)用于發(fā)送消息緩沖區(qū)的消息線程。每條消息都會(huì)排隊(duì)等待發(fā)送一次,一旦onCharacteristicWrite成功,該特征就會(huì)寫(xiě)入下一條消息。特性也設(shè)置為WRITE_TYPE_NO_RESPONSE,因此特性寫(xiě)入調(diào)用之間的消息緩沖隊(duì)列非??欤ù蠹s 0-7 毫秒)。主要問(wèn)題:“堵塞”特征在大多數(shù)情況下,這效果很好。當(dāng)存在大量消息時(shí),似乎會(huì)出現(xiàn)此問(wèn)題(可能會(huì)在消息較少時(shí)發(fā)生,但在發(fā)送大量消息時(shí)更明顯)。發(fā)生的情況是writeCharacteristicwill 被調(diào)用,并且該特性似乎鎖定,因?yàn)閛nCharacteristicChanged不再讀取任何新數(shù)據(jù),并且無(wú)法訪問(wèn)onCharacteristicWrite.我注意到的其他事情:每次添加 5-10ms 的睡眠延遲characteristicWrite似乎有幫助,但我不明白為什么藍(lán)牙 GATT 對(duì)象在成功返回時(shí)需要延遲onCharacteristicWrite。onConnectionStateChange有時(shí)我會(huì)收到狀態(tài) 8、設(shè)備超出范圍的回調(diào)。但這并不總是發(fā)生。有時(shí)characteristicWrite返回 false;然而,它也可以在進(jìn)入上述“堵塞特征”狀態(tài)之前返回 true消息線程代碼:    private boolean stopMessageThread = false;    private boolean characteristicWriteSuccessful = true;    private ArrayList<byte[]> messageQueue = new ArrayList<byte[]>();    private Thread messageThread =  new Thread( new Runnable() {        private long lastTime = 0;        private int count = 0;        @Override        public void run() {            while (!Thread.currentThread().isInterrupted() && !stopMessageThread) {                if(messageQueue.size() != 0 && characteristicWriteSuccessful) {                    Log.i(TAG, ""+(System.currentTimeMillis()-lastTime));                    Log.i(TAG, "Queue count: "+messageQueue.size());                    characteristicWriteSuccessful = false;                    byte[] message = messageQueue.remove(0);                    customCharacteristic.setValue(message);                    boolean status = bluetoothGatt.writeCharacteristic(customCharacteristic);                    Log.i(TAG, "write characteristic status "+status);                    lastTime = System.currentTimeMillis();                    //sleep(10); // this kinda helps but can still throw the error                }            }        }    });
查看完整描述

1 回答

?
呼喚遠(yuǎn)方

TA貢獻(xiàn)1856條經(jīng)驗(yàn) 獲得超11個(gè)贊

除了繁忙的等待(這會(huì)阻塞整個(gè) CPU 并快速耗盡電池)之外,我看不到任何同步。有共享數(shù)據(jù)結(jié)構(gòu)(可能是stopMessageThread、characteristicWriteSuccessful和messageQueue)和多個(gè)訪問(wèn)它們的線程。如果沒(méi)有同步,就會(huì)出現(xiàn)競(jìng)爭(zhēng)條件,并且堵塞可能是其表現(xiàn)。


所以我建議采用更簡(jiǎn)單的設(shè)計(jì),特別是沒(méi)有用于發(fā)送消息的線程:


private ArrayList<byte[]> messageQueue = new ArrayList<byte[]>();

private boolean isSending = false;


void sendMessage(byte[] message) {

    synchronized (this) {

        if (isSending) {

            messageQueue.add(message);

            return;

        }

        isSending = true;

    }

    customCharacteristic.setValue(message);

    bluetoothGatt.writeCharacteristic(customCharacteristic);

}


public void onCharacteristicWrite (BluetoothGatt gatt, 

                BluetoothGattCharacteristic characteristic, 

                int status) {

    byte[] message;

    synchronized (this) {

        if (messageQueue.size() == 0) {

            isSending = false;

            return;

        }

        message = messageQueue.remove(0);

    }

    customCharacteristic.setValue(message);

    bluetoothGatt.writeCharacteristic(customCharacteristic); 

}

該解決方案的假設(shè)是writeCharacteristic不會(huì)阻塞并且速度很快。這是一個(gè)安全的假設(shè),因?yàn)樵摲椒ㄔ谠O(shè)計(jì)上是異步的:它有一個(gè)回調(diào),將在操作完成時(shí)調(diào)用。


因此回調(diào)onCharacteristicWrite用于發(fā)送緩沖區(qū)中的下一條消息。因此,對(duì)線程的需求消失了——相關(guān)的復(fù)雜性也消失了。


當(dāng)從后臺(tái)線程調(diào)用回調(diào)時(shí),仍然涉及多個(gè)線程。因此,對(duì)共享數(shù)據(jù)的訪問(wèn)是同步的。


查看完整回答
反對(duì) 回復(fù) 2023-10-13
  • 1 回答
  • 0 關(guān)注
  • 715 瀏覽
慕課專(zhuān)欄
更多

添加回答

舉報(bào)

0/150
提交
取消
微信客服

購(gòu)課補(bǔ)貼
聯(lián)系客服咨詢優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動(dòng)學(xué)習(xí)伙伴

公眾號(hào)

掃描二維碼
關(guān)注慕課網(wǎng)微信公眾號(hào)