我对Android的开发非常陌生,所以我很抱歉,如果我想要的东西真的很简单的话,我在过去的几个小时里一直在谷歌搜索,没有运气。
在我的MainActivity中,我在意图中引用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个变量,一个上下文、一个通知和一个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.access$1700(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.access$1700(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() {发布于 2015-01-02 02:21:50
如果在这里引发异常:
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设置(提示:赋值)任何东西。
(但假设情况下,如果SDK是变量,它是null,initiate是实例方法,则会给出NPE。)SDK变量不是null,也可能有另一个SDK声明。总之,这证明不了什么。
https://stackoverflow.com/questions/27736661
复制相似问题