这段时间做的一个项目要用到蓝牙模块,用来和单片机进行通信,之后遇到了一个一个问题让我头疼很久:当程序运行到socket.connect();
的时候会出现下面这种错误:
read failed, socket might closed or timeout.
困扰了我整整两天的时间,最后发现是由于我在不同的线程调用同一个socket通道,导致错误产生.
解决办法:在bluetooth的管理类bluetoothManager
的变量初始化中加入如下判断:
BluetoothManager.device = null;
if(socket != null){
try {
socket.close();
} catch (IOException e) {
e.printStackTrace();
}
socket = null;
}
java多线程时调用同一个对象会发证很多不可预知的错误,必须要想办法解决或者避免.
这里是BluetoothSocketde全部代码.
/**
* Created by prell on 2017/8/7.
* 作为蓝牙的管理类,方便连接指定蓝牙并且进行数据交互
*/
public class BluetoothManager {
public static BluetoothDevice device;
public static BluetoothSocket socket;
public static boolean isInputtedPassword = false;
public static void set(BluetoothDevice device){
BluetoothManager.device = null;
if(socket != null){
try {
socket.close();
} catch (IOException e) {
e.printStackTrace();
}
socket = null;
}
isInputtedPassword = false;
BluetoothManager.device = device;
try {
//目标设备的UUID
UUID uuid = UUID.fromString("00001101-0000-1000-8000-00805F9B34FB");
socket = device.createRfcommSocketToServiceRecord(uuid);
}
catch (IOException e) {
Log.e("bt socket", "IOException");
}
}
@Override
public String toString(){
return "Now connecting bluetooth device is : " + device.getName() + " ;mac is : "+device.getAddress();
}
}