这是一篇关于之前工作成果的补记。我之前在一家可穿戴设备公司工作,主要工作之一是帮助改进和维护本司的android手机App和本司可穿戴设备(下文简称设备)之间蓝牙通信性能。曾经有一个性能问题困扰了公司很久,就是android手机app和设备之间的(蓝牙)同步成功率很低。相比于iOS手机App和所有设备之间轻松90%+的同步成功率,我们的Android App和各种设备的同步成功率仅仅70%~80%,GoogleStore上面用户对于我们app的差评一半以上跟“设备难以同步”有关。 于是公司决心彻底解决这个问题,我被征调以技术攻关。在经过了不断的尝试后,我们终于比较圆满的解决了这个问题。
首先当然是分析问题。我们对android用户同步失败的具体环节在代码里做了追踪,分析了至少前后半年的数据。我们发现在所有失败原因里,连接失败大约占六到七成,其余的包括扫描超时,连接参数设置失败,蓝牙读取文件失败等等。所以,我们的重点自然是蓝牙连接失败。在网上能够搜到有关Android平台上蓝牙性能不好的很多帖子,基本没有形成立竿见影的解决方案。我只好去看代码,反复阅读我们自己App调用蓝牙的代码,以及android.bluetooth API的实现代码。android蓝牙调用连接的示例代码很简单,扫描获取一个BluetoothDevice 后,调用它的connectGatt()方法,会返回一个BluetoothGatt。之后这个连接上的所有操作,包括连接状态变化,关闭连接,读写文件等,都在这个BluetoothGatt上操作。
public class BluetoothDevice {
...
public BluetoothGatt connectGatt(Context context, boolean