DialogFragment神秘的Null指针异常

时间:2015-03-01 23:56:26

标签: java android eclipse fragment android-dialogfragment

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

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。所以我让这两个DialogFragments独立工作。但现在我从CatDialog的FacebookDialog方法中启动onCreateView。这就是崩溃的原因。启动是有条件的,如下面的代码所示

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");

    }

2 个答案:

答案 0 :(得分:2)

您正在dismiss()内拨打requestFaceBookPublishPermission,这完全是怪人!如果您从另一个DialogFragment的onCreateView内部调用它,则无法执行此操作。所以你种子让两者分开。但是很好的问题。

所以要明白你在做什么:在onCreateView内返回视图之前,你正在解雇。你正在抢先一步。

答案 1 :(得分:1)

之前我遇到过这个问题。然后我解雇了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(); 
        }
    }