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() {
那么只有可能的解释是SDK
是null
。检查是否正确初始化;即,一个非空值已被 分配 给它。 (并检查你没有多个声明......并且其中一些没有初始化。)
您张贴此作为(假定的)反证。
SDK.initiate(getActivity(), "DEVCODE", new String[] { Scope },
new AuthListener() {
这不会将 SDK
设置为非空值。它没有设置(提示:分配)任何东西给SDK
。
(但假设会给出一个NPE如果SDK
是一个变量,它是null
并且initiate
是一个实例方法。)
该语句可能无法执行。
即使 that SDK
变量不是 null
,也可能有另一个 SDK
的声明。
简而言之,这并不能证明什么。
我是 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() {
那么只有可能的解释是SDK
是null
。检查是否正确初始化;即,一个非空值已被 分配 给它。 (并检查你没有多个声明......并且其中一些没有初始化。)
您张贴此作为(假定的)反证。
SDK.initiate(getActivity(), "DEVCODE", new String[] { Scope },
new AuthListener() {
这不会将
SDK
设置为非空值。它没有设置(提示:分配)任何东西给SDK
。(但假设会给出一个NPE如果
SDK
是一个变量,它是null
并且initiate
是一个实例方法。)该语句可能无法执行。
即使 that
SDK
变量不是null
,也可能有另一个SDK
的声明。
简而言之,这并不能证明什么。