在断开连接时候,调用socket.close()方法,发现程序直接闪退了,只有简单的一行提示如下:
断开连接关闭socket时候失败了。。。
百度查了一波,发现也有人遇到类似的问题,但是都没有很清楚的说明什么原因和解决办法。
我分析了下我的代码,感觉最大的可能就是socket的创建以及close的调用都是在直接在android的service中进行而造成的缘故,类似android规定不能在界面线程中做网络请求以及耗时操作一样。
所以,我首先在close的时候,把close方法放到new Thread中让单独线程去处理,但是,发现还是闪退。
然后,我把创建socket的代码以及connect的代码全部放到独立线程中去处理时,发现问题解决了。
也就是说:
创建socket的时候,以及进行connect的时候,必须新开一个独立线程进行操作,不能在主线程中,否则在close的时候会闪退。
public void bp_connect(final BluetoothDevice device)
{
if (device != null)
{
new Thread(new Runnable() {
@Override
public void run()
{
try
{
socket = device.createRfcommSocketToServiceRecord(MY_UUID);
socket.connect();
Intent intent = new Intent(BluStaValue.ACTION_CONNECT_ING);
lbm.sendBroadcast(intent);
connected();
}
catch (IOException e)
{
e.printStackTrace();
connectionFailed();
}
}
}).start();
}
}