【发布时间】: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