java - Fragment 中的通知管理器

标签 java android nullpointerexception notificationmanager

当我尝试在 fragment 类中为通知管理器分配值时,出现空指针异常。

    private NotificationManager m_notificationMgr;

public void CreateNotification() {
    Log.d(TAG, "created");

    m_stopwatch = new Stopwatch();
    m_notificationMgr = (NotificationManager)getSystemService(Context.NOTIFICATION_SERVICE);//null pointer exception

    createNotification();
    Log.d(TAG, "ok");
}

错误日志

05-15 12:31:16.127: E/AndroidRuntime(2216): FATAL EXCEPTION: main
05-15 12:31:16.127: E/AndroidRuntime(2216): java.lang.RuntimeException: Unable to start activity ComponentInfo{com.example.timetracker/com.example.timetracker.MainActivity}: java.lang.NullPointerException
05-15 12:31:16.127: E/AndroidRuntime(2216):     at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2211)
05-15 12:31:16.127: E/AndroidRuntime(2216):     at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2261)
05-15 12:31:16.127: E/AndroidRuntime(2216):     at android.app.ActivityThread.access$600(ActivityThread.java:141)
05-15 12:31:16.127: E/AndroidRuntime(2216):     at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1256)
05-15 12:31:16.127: E/AndroidRuntime(2216):     at android.os.Handler.dispatchMessage(Handler.java:99)
05-15 12:31:16.127: E/AndroidRuntime(2216):     at android.os.Looper.loop(Looper.java:137)
05-15 12:31:16.127: E/AndroidRuntime(2216):     at android.app.ActivityThread.main(ActivityThread.java:5103)
05-15 12:31:16.127: E/AndroidRuntime(2216):     at java.lang.reflect.Method.invokeNative(Native Method)
05-15 12:31:16.127: E/AndroidRuntime(2216):     at java.lang.reflect.Method.invoke(Method.java:525)
05-15 12:31:16.127: E/AndroidRuntime(2216):     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:737)
05-15 12:31:16.127: E/AndroidRuntime(2216):     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:553)
05-15 12:31:16.127: E/AndroidRuntime(2216):     at dalvik.system.NativeStart.main(Native Method)
05-15 12:31:16.127: E/AndroidRuntime(2216): Caused by: java.lang.NullPointerException
05-15 12:31:16.127: E/AndroidRuntime(2216):     at android.content.ContextWrapper.getSystemService(ContextWrapper.java:519)
05-15 12:31:16.127: E/AndroidRuntime(2216):     at com.example.timetracker.StopwatchService.Create(StopwatchService.java:51)
05-15 12:31:16.127: E/AndroidRuntime(2216):     at com.example.timetracker.MainActivity.onCreate(MainActivity.java:125)
05-15 12:31:16.127: E/AndroidRuntime(2216):     at android.app.Activity.performCreate(Activity.java:5133)
05-15 12:31:16.127: E/AndroidRuntime(2216):     at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1087)
05-15 12:31:16.127: E/AndroidRuntime(2216):     at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2175)
05-15 12:31:16.127: E/AndroidRuntime(2216):     ... 11 more

最佳答案

试试这个方法

 m_notificationMgr = (NotificationManager)getActivity().getSystemService(getActivity().NOTIFICATION_SERVICE);

而不是

 m_notificationMgr = (NotificationManager)getSystemService(Context.NOTIFICATION_SERVICE);

它在Frgament中运行良好。

关于java - Fragment 中的通知管理器,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/23678555/

相关文章:

java - 如何在给出答案后重新启动计算器

java - 如何读取保存编码的文件?

null - 什么编程语言可以防止空指针异常?

java - NullPointerException 使用 ImageIO.read

java - hadoop中的分区文件是如何创建的

java - 方法 wait() 和 notifyAll() 不是静态的

java - andengine中如何给游戏场景添加背景音乐

android - 计时器在 Android 中不停止

java - Android 中的过滤数组

android - 选项卡 View 问题,无法设置内容 View