【问题标题】:android - bluetooth adapter - message handler buffer limitandroid - 蓝牙适配器 - 消息处理程序缓冲区限制
【发布时间】:2016-02-02 15:22:14
【问题描述】:

我正在使用本教程构建使用蓝牙进行连接的多人游戏:

https://developer.android.com/samples/BluetoothChat/index.html

由于我发送的是 JSON 格式的长字符串(长度为 5500+),因此消息处理程序方法不会返回我发送的整个字符串,而是将它们拆分为 989 个字符长的字符串(其长度始终为 989 个字符) )。问题是,当我尝试解析 JSON 字符串时,显然会引发错误,因为文本不完整。当我在控制台中打印出字符串时,它会将它们打印成由 989 个字符分割的多行。

另外请注意,缓冲区长度设置为 1024,但是当我增加限制时,结果不会有所不同,并且始终是 989 个字符。

byte[] buffer = new byte[1024];

知道发生了什么吗?这是消息处理程序方法。请注意,从主机设备发送的消息看起来很好(它没有拆分),但是当客户端收到它时,它会拆分成多个字符串。

private static final Handler mHandler = new Handler() {
    @Override
    public void handleMessage(Message msg) {
        switch (msg.what) {
            case BluetoothService.MESSAGE_STATE_CHANGE:
                switch (msg.arg1) {
                    case BluetoothService.STATE_CONNECTED:
                    case BluetoothService.STATE_CONNECTING:
                    case BluetoothService.STATE_LISTEN:
                    case BluetoothService.STATE_NONE:
                        break;
                }
                break;
            case BluetoothService.MESSAGE_WRITE:
                // BYTE LENGTH IS OK IN HERE!
                byte[] writeBuf = (byte[]) msg.obj;
                String writeMessage = new String(writeBuf);
                break;
            case BluetoothService.MESSAGE_READ:
                // BYTE LENGTH IS 1024 IN HERE!
                byte[] readBuf = (byte[]) msg.obj;
                message = new String(readBuf, 0, msg.arg1);
                break;
        }
    }
};

【问题讨论】:

    标签: java android bluetooth buffer


    【解决方案1】:

    通过Bluetooth 套接字传递的数据被抽象为流,但在传输层被分解为最大大小约为 1000 字节的数据包。在发送方,您可以获得输出流并写入 5 KB 的数据块,但传输层会在通过空中发送之前将其分解为多个数据包。当接收方读取其输入流时,每次调用read() 都会返回一个数据包的数据。传输层不会重新组装数据包,您的代码需要这样做。这意味着您需要设计一些方案,例如包含消息长度的消息头,接收方可以知道何时停止组装数据包并将完整的消息交给消费处理。

    BluetoothChat 示例应用程序未解决此问题,因为它(默默地)假定所有聊天消息都小于数据包大小,因此不需要重新组装消息。

    【讨论】:

    • 很好的建议!谢谢!
    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 2014-12-31
    • 2016-10-24
    • 1970-01-01
    • 1970-01-01
    • 2013-08-10
    • 1970-01-01
    • 2013-05-19
    相关资源
    最近更新 更多