【问题标题】:App crashes when replacing Fragments [duplicate]替换片段时应用程序崩溃[重复]
【发布时间】:2016-09-26 20:30:37
【问题描述】:

我开始学习 Fragments,以便在我的应用中实现 NavigationDrawer。

我配置了 NavigationDrawer,然后创建了 2 个 Fragment:MainFragment、GalleryFragment。

在我的 app_bar_main 中,我制作了一个 fragment_container:

app_bar_main:

<FrameLayout
    xmlns:android="http://schemas.android.com/apk/res/android"
    android:id="@+id/fragment_container"
    android:layout_width="match_parent"
    android:layout_height="match_parent">

</FrameLayout>

到目前为止,我可以启动应用程序并且它可以正常工作,但 NavigationDrawer 的效果为零。

当我想用我的片段之一替换占位符时,应用程序崩溃:

主要活动:

MainFragment fragment = new MainFragment();
android.support.v4.app.FragmentTransaction fragmentTransaction = getSupportFragmentManager().beginTransaction();
fragmentTransaction.replace(R.id.fragment_container, fragment);
fragmentTransaction.addToBackStack(null);
fragmentTransaction.commit();

调试:

    09/26 22:25:24: Launching app
Cold swapped changes.
$ adb shell am start -n "com.example.kasimir.schulplaner/com.example.kasimir.schulplaner.MainActivity" -a android.intent.action.MAIN -c android.intent.category.LAUNCHER -D
Waiting for application to come online: com.example.kasimir.schulplaner | com.example.kasimir.schulplaner.test
Waiting for application to come online: com.example.kasimir.schulplaner | com.example.kasimir.schulplaner.test
Connecting to com.example.kasimir.schulplaner
I/art: Ignoring second debugger -- accepting and dropping

安卓监视器:

FATAL EXCEPTION: main
                                                   Process: com.example.kasimir.schulplaner, PID: 26444
                                                   java.lang.RuntimeException: Unable to start activity ComponentInfo{com.example.kasimir.schulplaner/com.example.kasimir.schulplaner.MainActivity}: java.lang.RuntimeException: com.example.kasimir.schulplaner.MainActivity@753f53 must implement OnFragmentInteractionListener
                                                       at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2456)
                                                       at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2539)
                                                       at android.app.ActivityThread.access$900(ActivityThread.java:159)
                                                       at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1384)
                                                       at android.os.Handler.dispatchMessage(Handler.java:102)
                                                       at android.os.Looper.loop(Looper.java:152)
                                                       at android.app.ActivityThread.main(ActivityThread.java:5507)
                                                       at java.lang.reflect.Method.invoke(Native Method)
                                                       at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:726)
                                                       at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:616)
                                                    Caused by: java.lang.RuntimeException: com.example.kasimir.schulplaner.MainActivity@753f53 must implement OnFragmentInteractionListener
                                                       at com.example.kasimir.schulplaner.MainFragment.onAttach(MainFragment.java:84)
                                                       at android.support.v4.app.FragmentManagerImpl.moveToState(FragmentManager.java:1043)
                                                       at android.support.v4.app.BackStackRecord.setLastIn(BackStackRecord.java:838)
                                                       at android.support.v4.app.BackStackRecord.calculateFragments(BackStackRecord.java:878)
                                                       at android.support.v4.app.BackStackRecord.run(BackStackRecord.java:719)
                                                       at android.support.v4.app.FragmentManagerImpl.execPendingActions(FragmentManager.java:1677)
                                                       at android.support.v4.app.FragmentController.execPendingActions(FragmentController.java:388)
                                                       at android.support.v4.app.FragmentActivity.onStart(FragmentActivity.java:604)
                                                       at android.support.v7.app.AppCompatActivity.onStart(AppCompatActivity.java:178)
                                                       at android.app.Instrumentation.callActivityOnStart(Instrumentation.java:1277)
                                                       at android.app.Activity.performStart(Activity.java:6321)
                                                       at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2419)
                                                       at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2539) 
                                                       at android.app.ActivityThread.access$900(ActivityThread.java:159) 
                                                       at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1384) 
                                                       at android.os.Handler.dispatchMessage(Handler.java:102) 
                                                       at android.os.Looper.loop(Looper.java:152) 
                                                       at android.app.ActivityThread.main(ActivityThread.java:5507) 
                                                       at java.lang.reflect.Method.invoke(Native Method) 
                                                       at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:726) 
                                                       at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:616) 
09-26 22:32:37.725 26444-26444/? D/AppTracker: App Event: crash
09-26 22:32:37.729 3402-4542/? W/ActivityManager:   Force finishing activity com.example.kasimir.schulplaner/.MainActivity
09-26 22:32:37.732 26444-26444/? I/Process: Sending signal. PID: 26444 SIG: 9
09-26 22:32:37.748 3402-26460/? D/DropBoxManagerService: file :: /data/system/dropbox/data_app_crash@2016-09-26-22_32_37_735.txt
09-26 22:32:37.751 3402-4554/? I/ActivityManager: Process com.example.kasimir.schulplaner (pid 26444) has died

【问题讨论】:

  • 错误是什么?
  • 请记住,在 Java 中,所有代码都放在一个类和方法中。如果您将代码 sn-ps 包装在类和方法声明中,就像您在实际代码中一样,它将帮助我们了解您在做什么。
  • 我用来自 androidstudio 的一些信息编辑了这篇文章。该应用程序也只是闪烁白色然后终止。如果您需要更多信息,请告诉我。并且尝试正确编辑它@Code-Apprentice
  • 而不是写“MainAtivity:”,你应该使用实际的Java语法来显示类名。您还应该包括包含代码行的方法。基本上,我们应该能够复制和粘贴您在此处发布的任何内容,并通过很少的更改进行编译,例如添加正确的导入。

标签: android android-fragments


【解决方案1】:

MainActivity@753f53 必须实现 OnFragmentInteractionListener

这是不言自明的。 OnFragmentInteractionListener 是在您创建项目时生成的。这是用于在片段与其托管活动之间进行通信的常用技术。您有两个选择:1)实现接口或 2)删除它。

【讨论】:

  • 对不起,如果这是重复的,我做了一些搜索,但没有找到有用的东西。
  • @Conwear 假设您在某个地方遵循了指南,那么 Activity 代码应该已经实现了该接口。
猜你喜欢
  • 2014-06-05
  • 1970-01-01
  • 2018-10-07
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2018-08-26
  • 1970-01-01
相关资源
最近更新 更多