【问题标题】:DialogFragment mysterious Null Pointer ExceptionDialogFragment 神秘的空指针异常
【发布时间】:2015-03-01 23:56:26
【问题描述】:

我似乎无法从 eclipse 给我的堆栈跟踪中找出头或尾。该代码用于工作。我不确定我改变了什么。但是现在当我启动对话框片段时,应用程序崩溃并显示以下错误日志。

FATAL EXCEPTION: main
 Process: com.company.appname, PID: 8962
 java.lang.NullPointerException
    at android.support.v4.app.DialogFragment.onActivityCreated(DialogFragment.java:366)
    at android.support.v4.app.Fragment.performActivityCreated(Fragment.java:1508)
    at android.support.v4.app.FragmentManagerImpl.moveToState(FragmentManager.java:958)
    at android.support.v4.app.FragmentManagerImpl.moveToState(FragmentManager.java:1115)
    at android.support.v4.app.BackStackRecord.run(BackStackRecord.java:682)
    at android.support.v4.app.FragmentManagerImpl.execPendingActions(FragmentManager.java:1478)
    at android.support.v4.app.FragmentManagerImpl$1.run(FragmentManager.java:446)
    at android.os.Handler.handleCallback(Handler.java:733)
    at android.os.Handler.dispatchMessage(Handler.java:95)
    at android.os.Looper.loop(Looper.java:136)
    at android.app.ActivityThread.main(ActivityThread.java:5579)
    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:1268)
    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1084)
    at dalvik.system.NativeStart.main(Native Method)

我的代码很大,所以我不确定要显示哪个部分。所以也许有人在我的代码中看到了这种神秘的崩溃,显然没有根(即,因为 eclipse 没有命名)

更新

好的。我找到了罪魁祸首。但我仍然不知道如何解决它。所以我有 CatDialog(现在崩溃的那个)和 FacebookDialog。所以我让这两个 DialogFragment 独立工作。但现在我从 CatDialog 的 onCreateView 方法内部启动 FacebookDialog。这就是崩溃的原因。启动是有条件的,如下代码所示

protected void requestFaceBookPublishPermission() {
        Log.i(TAG, "going into requestFaceBookPublishPermission");
        Session session = Session.getActiveSession();
        if (session == null || !session.isOpened() ||
            !session.isPermissionGranted(FacebookDialog.PERMISSION)) {
            FacebookDialog fb = new FacebookDialog();
            fb.show(getChildFragmentManager(), "fb");
            dismiss();
        }
        Log.i(TAG, "leaving requestFaceBookPublishPermission");

    }

【问题讨论】:

  • DialogFragment.java:366 - 这是要显示的部分。
  • 我没有 366 行。
  • @KatedralPillon:我认为是某些对话框片段在您的代码中的某处初始化不正确,这可能会导致错误。您能否将问题限制在您执行的某些操作或代码中的一些位置?否则可能很难提供帮助。
  • 如果您查看grepcode.com/file/repository.grepcode.com/java/ext/… 处的代码,您会发现mDialog 仅在getLayoutInflater 中实例化了一次,或许您可以从中找出答案?

标签: java android eclipse fragment android-dialogfragment


【解决方案1】:

你从requestFaceBookPublishPermission 内部打电话给dismiss(),这太古怪了!如果您从另一个 DialogFragment 的 onCreateView 内部调用它,则不能这样做。因此,您播种以使两者再次分开。不过这个问题很好。

所以了解你在做什么:在返回 onCreateView 中的视图之前,你正在解散。你是先发制人。

【讨论】:

  • 我删除了dismiss方法,一切恢复正常。你可能知道一些方法让它以某种方式一起工作吗?问题是,如果我必须进入 if 语句,那么我不再需要当前的 DialogFragment,因此想以某种方式摆脱它。
【解决方案2】:

我以前遇到过这个问题。然后我关闭了 oncreateView 中的对话框,我得到了 NullpointerException。然后我将我的代码移动到 onResume() 来关闭对话框,问题就解决了!

错误

public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) {
    View view = inflater.inflate(R.layout.fragment_home, container, false); 

if(something){

} else{
    dismiss(); //Dismissing dialog here gives NullpointerException
    }
}
return view;

正确

 @Override
 public void onResume() {
    super.onResume();

if(something){
    } else{
        dismiss(); 
        }
    }

【讨论】: