BroadcastReceiver 中的 NullPointerException

NullPointerException in BroadcastReceiver

我是 Android 开发的新手,所以如果我问的问题真的很简单,我事先表示歉意,过去几个小时我一直在谷歌搜索,但没有成功。

在我的 MainActivity 中,我在 Intent 中引用 AlarmReceiver.class,然后引用到 PendingIntent,最后它被设置为 AlarmManager。我这样做是为了设置一个警报,这很好用,当警报被触发时,异常就会发生。

    Intent intent = new Intent(ourContext, AlarmReceiver.class);

    PendingIntent pendingIntent = PendingIntent.getBroadcast(ourContext, 666, intent, 0);

    AlarmManager alarmManager = (AlarmManager) ourContext.getSystemService(Context.ALARM_SERVICE);

    alarmManager.set(AlarmManager.RTC_WAKEUP, targetCal.getTimeInMillis(), pendingIntent);

然后在AlarmReceiver.class中它扩展了BroadcastReceiver,并进行了SDK调用。 这部分代码在警报触发时运行,这意味着当所选时间快到时,运行此代码。

public void onReceive(Context arg0, Intent arg1) {

    SDK.sendNotification(arg0, new Notification("alarm", "Top Line", "Bottom Line"), new SendNotificationListener() {

        @Override
        public void onSuccess(String s) {
            Log.d("success", s);
        }

        @Override
        public void onFailed(String s) {
            Log.d("fail", s);
        }
    });
}

SendNotification 需要 3 个变量,一个上下文,一个 Notification 和一个 NotificationListener。

我能够确定的是,我很确定问题出在 NotificationListener 上并导致错误。

这是堆栈跟踪:

Process: com.example.timer:remote, PID: 27665
    java.lang.RuntimeException: Unable to start receiver com.example.timer.AlarmReceiver: java.lang.NullPointerException
            at android.app.ActivityThread.handleReceiver(ActivityThread.java:2452)
            at android.app.ActivityThread.access00(ActivityThread.java:144)
            at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1281)
            at android.os.Handler.dispatchMessage(Handler.java:102)
            at android.os.Looper.loop(Looper.java:136)
            at android.app.ActivityThread.main(ActivityThread.java:5146)
            at java.lang.reflect.Method.invokeNative(Native Method)
            at java.lang.reflect.Method.invoke(Method.java:515)
            at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:796)
            at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:612)
            at de.robv.android.xposed.XposedBridge.main(XposedBridge.java:132)
            at dalvik.system.NativeStart.main(Native Method)
     Caused by: java.lang.NullPointerException
            at com.example.imer.AlarmReceiver.onReceive(AlarmReceiver.java:21)
            at android.app.ActivityThread.handleReceiver(ActivityThread.java:2445)
            at android.app.ActivityThread.access00(ActivityThread.java:144)
            at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1281)
            at android.os.Handler.dispatchMessage(Handler.java:102)
            at android.os.Looper.loop(Looper.java:136)
            at android.app.ActivityThread.main(ActivityThread.java:5146)
            at java.lang.reflect.Method.invokeNative(Native Method)
            at java.lang.reflect.Method.invoke(Method.java:515)
            at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:796)
            at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:612)
            at de.robv.android.xposed.XposedBridge.main(XposedBridge.java:132)
            at dalvik.system.NativeStart.main(Native Method)

这是第 21 行:

SDK.sendNotification(arg0, new Notification("alarm", "Top Line", "Bottom Line"), new SendNotificationListener() {

如果这里抛出异常:

  SDK.sendNotification(arg0, 
                       new Notification("alarm", "Top Line", "Bottom Line"), 
                       new SendNotificationListener() {

那么只有可能的解释是SDKnull。检查是否正确初始化;即,一个非空值已被 分配 给它。 (并检查你没有多个声明......并且其中一些没有初始化。)


您张贴此作为(假定的)反证。

  SDK.initiate(getActivity(), "DEVCODE", new String[] { Scope }, 
               new AuthListener() {
  1. 这不会将 SDK 设置为非空值。它没有设置(提示:分配)任何东西给SDK

    (但假设给出一个NPE如果SDK是一个变量,它是null并且initiate是一个实例方法。)

  2. 该语句可能无法执行。

  3. 即使 that SDK 变量不是 null,也可能有另一个 SDK 的声明。

简而言之,这并不能证明什么。