gpt4 book ai didi

Android 蓝牙 Inputstream.read 从不接收数据

转载 作者:行者123 更新时间:2023-11-29 02:04:54 28 4
gpt4 key购买 nike

我正在为 Android 制作一款游戏,其中两台设备连接并交换少量数据,然后断开连接并使用该数据。我从蓝牙聊天示例开始。在这一点上,我大部分时间都在工作,但有些(大多数)时间,其中一个设备从未收到任何数据。这是两个设备上的同一个应用程序,因此两者的发送和接收代码是相同的。我是这样连接的:

    public BluetoothClientThread(BluetoothDevice get_device,boolean secure){
BluetoothSocket temp=null;
device=get_device;
socket_type=secure?"Secure":"Insecure";

try{
if(secure){
temp=device.createRfcommSocketToServiceRecord(UUID_SECURE);
}
else{
temp=device.createRfcommSocketToServiceRecord(UUID_INSECURE);
}
}
catch(IOException e){
StorageManager.error_log_add(context,TAG,"create() on "+socket_type+" client socket failed.",e);
}

socket=temp;
}

public void run(){
bluetooth_adapter.cancelDiscovery();

try{
socket.connect();
}
catch(IOException e){
StorageManager.error_log_add(context,TAG,"Connection failed.",e);

try{
socket.close();
}
catch(IOException ioe){
StorageManager.error_log_add(context,TAG,"close() on "+socket_type+" client socket failed during connection failure.",ioe);
}

connection_failed();

return;
}

synchronized(BluetoothService.this){
bluetooth_client_thread=null;
}

connected(socket,device,socket_type,false);
}

连接后,我获取套接字的 getInputStream() 和 getOutputStream()。然后我使用以下代码读取套接字上的输入:

    public void run(){
String packet="";

while(true){
try{
int get_byte=input.read();
char get_char=(char)get_byte;

if(get_char!='\u0003'){
StorageManager.error_log_add(context,"BluetoothService","Adding packet raw data: \""+get_char+"\"",null);
packet+=get_char;
}
else{
StorageManager.error_log_add(context,"BluetoothService","Packet received:\n"+packet,null);
handler.obtainMessage(Activity_Battle_Menu.HANDLER_READ,packet).sendToTarget();
packet="";
}

if(done && they_done){
handler.obtainMessage(Activity_Battle_Menu.HANDLER_READY).sendToTarget();
}
}
catch(IOException e){
StorageManager.error_log_add(context,TAG,"Connection lost.",e);

connection_lost();

break;
}
}
}

它一次读取一个字节的数据,将字节附加到数据包字符串中。当到达 ETX 字符时(当我发送它时,我会把它贴在所有东西的末尾),一个完整的数据包已经收到,并通过处理程序传递给 Activity ,在那里它被执行。这是我写的代码:

    public void write(byte[] buffer){
try{
StorageManager.error_log_add(context,"BluetoothService","Writing data:\n"+new String(buffer),null);

output.write(buffer);
}
catch(IOException e){
StorageManager.error_log_add(context,TAG,"write() on "+socket_type+" connected socket failed.",e);
}
}

如您所见,我会在发送数据“数据包”、接收到一个字节以及接收到整个“数据包”时写入日志。

我不确定这是否相关,但是:我正在使用带有 Cyanogenmod 7.1 (Android 2.3.7) 和在 VirtualBox (Android 2.3.5) 中运行的 Android x86 的 Nook Color 对此进行测试。我的应用程序的 minSdkVersion 是 8 (Android 2.2)。对于在我的计算机上运行的 Android,我使用的是 Rocketfish USB 蓝牙适配器。

假设每个实例发送两个数据包。首先,发送包含所有需要的游戏数据的数据包。当接收到其他实例的游戏数据时,应用程序将自己的 bool 值 done 设置为 true。它还向另一个实例发送一个“完成”数据包。因此,一旦两个实例都完成,并且知道另一个实例已完成,我们就知道所有数据都已发送和接收,并且它们都断开/停止它们的蓝牙线程并对数据进行操作。

因为我在发送和接收数据时在两台设备上都记录了日志,所以日志告诉我发生了什么事。

-首先,我开始两个游戏并进入蓝牙 Activity (很明显)。

-接下来,我从模拟实例连接到 Nook 实例。

-模拟实例发送其游戏数据包。

-Nook 实例接收模拟实例的游戏数据,并发送自己的(有时这两个是按顺序切换的,只是因为它们是异步发生的)。

-由于收到游戏数据包,Nook 实例现在发送其“完成”数据包。

-就是这样。模拟实例从不接收任何一个数据包。它甚至从未接收到一个字节,input.read() 只是阻塞,等待永远不会到达的输入(就像它应该的那样)。

所以这是我的问题。似乎发生了以下两件事之一:

  1. Nook 实例上的 output.write() 永远不会发送数据,即使它没有抛出任何异常,并且日志会验证它是否被调用。

  2. 模拟实例上的 input.read() 永远不会接收到数据。也许它在传输中丢失了?

据我所知,我的代码非常可靠。问题似乎与蓝牙有关。也许一个或两个 Android 实例都有一个奇怪的蓝牙设置?

我还想补充一点,每隔一段时间(可能是 1/15 次),所有数据包都会正确发送和接收,并且游戏会正常进行。因此,任何错误只会经常发生,但并非总是如此。

最佳答案

我可以访问另一台带蓝牙的 Android 设备。从那以后,我测试了我的游戏,它可以正确连接并且设备可以正确交易数据。我在我的程序中发现了其他几个在蓝牙问题之后发生的错误,但那既不存在也不存在!

之前的 Nook Color 和 HTC Status 是一起工作的。那么,我正式得出结论,我的电脑上的蓝牙适配器有问题。上面发布的代码工作得很好。

关于Android 蓝牙 Inputstream.read 从不接收数据,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10568202/

28 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com