接收蓝牙发现的广播错误

时间:2012-04-29 22:01:30

标签: android bluetooth broadcastreceiver

我正在尝试寻找附近的蓝牙设备,因此我正在使用BroadcastReceiver。大部分时间它工作正常但有时我得到这个错误。

04-30 09:50:15.277: E/AndroidRuntime(847): FATAL EXCEPTION: main
04-30 09:50:15.277: E/AndroidRuntime(847): java.lang.RuntimeException: Error receiving broadcast Intent { act=android.bluetooth.device.action.FOUND (has extras) } in com.waratah.app.SetMachineActivity$2@40582d20
04-30 09:50:15.277: E/AndroidRuntime(847):  at android.app.LoadedApk$ReceiverDispatcher$Args.run(LoadedApk.java:722)
04-30 09:50:15.277: E/AndroidRuntime(847):  at android.os.Handler.handleCallback(Handler.java:587)
04-30 09:50:15.277: E/AndroidRuntime(847):  at android.os.Handler.dispatchMessage(Handler.java:92)
04-30 09:50:15.277: E/AndroidRuntime(847):  at android.os.Looper.loop(Looper.java:130)
04-30 09:50:15.277: E/AndroidRuntime(847):  at android.app.ActivityThread.main(ActivityThread.java:3683)
04-30 09:50:15.277: E/AndroidRuntime(847):  at java.lang.reflect.Method.invokeNative(Native Method)
04-30 09:50:15.277: E/AndroidRuntime(847):  at java.lang.reflect.Method.invoke(Method.java:507)
04-30 09:50:15.277: E/AndroidRuntime(847):  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:839)
04-30 09:50:15.277: E/AndroidRuntime(847):  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:597)
04-30 09:50:15.277: E/AndroidRuntime(847):  at dalvik.system.NativeStart.main(Native Method)
04-30 09:50:15.277: E/AndroidRuntime(847): Caused by: java.lang.NullPointerException
04-30 09:50:15.277: E/AndroidRuntime(847):  at com.waratah.app.SetMachineActivity$2.onReceive(SetMachineActivity.java:532)
04-30 09:50:15.277: E/AndroidRuntime(847):  at android.app.LoadedApk$ReceiverDispatcher$Args.run(LoadedApk.java:709)
04-30 09:50:15.277: E/AndroidRuntime(847):  ... 9 more

它显示了NullPointerException但我没有看到这个错误是如何发生的,因为我正在检查变量以避免异常。

// The BroadcastReceiver that listens for discovered devices and
// changes the title when discovery is finished
private final BroadcastReceiver mReceiver = new BroadcastReceiver() {
    @Override
    public void onReceive(Context context, Intent intent) {
        if (intent == null) {
            return;
        }
        String action = intent.getAction();
        int i;
        Machine d;

        if (BluetoothAdapter.ACTION_STATE_CHANGED.equals(action)) {
            if (mBtAdapter.isEnabled()) {
                if(D) Log.d(BroadcastReceiver.class.getName(), "Bluetooth is enabled");
                pd.dismiss();                   
            }
            doDiscovery();

        // when bluetooth device is found 
        } else if (BluetoothDevice.ACTION_FOUND.equals(action)) { 
            if(D) Log.d(BroadcastReceiver.class.getName(), "found");
            // Get the BluetoothDevice object from the Intent
            BluetoothDevice device = intent.getParcelableExtra(BluetoothDevice.EXTRA_DEVICE);
            if (device != null) {

                // Check if the device has name
                if ((device.getName() != null)||(device.getName().length() > 0)) { //LINE 532 HERE 
                    d = new Machine(device);
                    if (d.getPairingState() != BluetoothDevice.BOND_BONDED) {
                        d.setBluetoothState(true);
                        addDevice(d);
                    } else {
                        for (i = 0; i < adapter.getCount(); i++) {
                            if (adapter.getItem(i).getAddress().equals(device.getAddress())) {
                                    adapter.getItem(i).setBluetoothState(true);
                            }
                        }
                    }
                }
            }
        // When discovery is finished, change the Activity title
        } else if (BluetoothAdapter.ACTION_DISCOVERY_FINISHED.equals(action)) {
            scanButton.setVisibility(View.VISIBLE);

            pb.setVisibility(View.GONE);
            scanning.setVisibility(View.GONE);
        }
    }
};

我已经注册了所有操作并正确注册了我的接收器。仅偶尔发生此错误。当没有东西可以接收时,是否可以触发onReceive()函数?

感谢您的帮助。

编辑: 第532行是

 if ((device.getName() != null)||(device.getName().length() > 0)) { 

所以这意味着设备必须为null,但前一行检查这一点。

if (device != null) {

顺便说一下,两个同时运行的广播接收器会导致这种错误吗? BroadcastReceiver收到后是否使意图为空?

1 个答案:

答案 0 :(得分:2)

我怀疑你错误地使用了||而不是&amp;&amp;。

if ((device.getName() != null)||(device.getName().length() > 0)) {

VS

if ((device.getName() != null) && (device.getName().length() > 0)) {

如最初编写的那样,如果device.getName()为null,则它会尝试计算第二部分,即在null值上调用length(),从而产生您所看到的NPE。