繁体   English   中英

Android Studio 中片段的 InflateException、Fragment$InstantiationException

[英]InflateException, Fragment$InstantiationException for Fragments in Android Studio

我使用右键单击 Java 项目文件夹 -> 新建 -> 片段创建了两个演示片段类和相应的片段布局,并保留 IDE 生成的所有内容。

我的文件是 -

  • TopSectionFragment.java
  • frag.net_top_section.xml
  • BottomImageFrag.net.java
  • fragment_bottom_image.xml

在我的activity_main.xml文件中,我使用了如下片段 -

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout
    xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    tools:context=".MainActivity"
    android:layout_margin="20dp">


    <fragment
        android:id="@+id/fragment"
        android:name="com.example.fragmentdemo.TopSectionFragmnet"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        tools:layout="@layout/fragment_top_section" />

    <fragment
        android:id="@+id/fragment2"
        android:name="com.example.fragmentdemo.BottomImageFragment"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        tools:layout="@layout/fragment_bottom_image"
        android:layout_below="@id/fragment"/>
    
</RelativeLayout>

MainActivity.java文件是IDE默认生成的

当我在模拟器中运行程序时,我的 IDE 显示“成功”,但模拟器显示“应用一直停止 -> 应用信息,关闭应用”

Analyze -> Stack Trace 或 Thread Dump 信息如下 -


01/14 02:47:32: Launching 'app' on Pixel 4 API 28.
App restart successful without requiring a re-install.
$ adb shell am start -n "com.example.fragmentdemo/com.example.fragmentdemo.MainActivity" -a android.intent.action.MAIN -c android.intent.category.LAUNCHER
Connected to process 10882 on device 'Pixel_4_API_28 [emulator-5554]'.
Capturing and displaying logcat messages from application. This behavior can be disabled in the "Logcat output" section of the "Debugger" settings page.
D/AndroidRuntime: Shutting down VM
E/AndroidRuntime: FATAL EXCEPTION: main
    Process: com.example.fragmentdemo, PID: 10882
    java.lang.RuntimeException: Unable to start activity ComponentInfo{com.example.fragmentdemo/com.example.fragmentdemo.MainActivity}: android.view.InflateException: Binary XML file line #11: Binary XML file line #11: Error inflating class fragment
        at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2913)
        at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:3048)
        at android.app.servertransaction.LaunchActivityItem.execute(LaunchActivityItem.java:78)
        at android.app.servertransaction.TransactionExecutor.executeCallbacks(TransactionExecutor.java:108)
        at android.app.servertransaction.TransactionExecutor.execute(TransactionExecutor.java:68)
        at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1808)
        at android.os.Handler.dispatchMessage(Handler.java:106)
        at android.os.Looper.loop(Looper.java:193)
        at android.app.ActivityThread.main(ActivityThread.java:6669)
        at java.lang.reflect.Method.invoke(Native Method)
        at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:493)
        at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:858)
     Caused by: android.view.InflateException: Binary XML file line #11: Binary XML file line #11: Error inflating class fragment
     Caused by: android.view.InflateException: Binary XML file line #11: Error inflating class fragment
     Caused by: android.app.Fragment$InstantiationException: Trying to instantiate a class com.example.fragmentdemo.TopSectionFragmnet that is not a Fragment
        at android.app.Fragment.instantiate(Fragment.java:526)
        at android.app.FragmentContainer.instantiate(FragmentContainer.java:53)
        at android.app.FragmentManagerImpl.onCreateView(FragmentManager.java:3547)
        at android.app.FragmentController.onCreateView(FragmentController.java:102)
        at android.app.Activity.onCreateView(Activity.java:6323)
        at android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:780)
        at android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:730)
        at android.view.LayoutInflater.rInflate(LayoutInflater.java:863)
        at android.view.LayoutInflater.rInflateChildren(LayoutInflater.java:824)
        at android.view.LayoutInflater.inflate(LayoutInflater.java:515)
        at android.view.LayoutInflater.inflate(LayoutInflater.java:423)
        at android.view.LayoutInflater.inflate(LayoutInflater.java:374)
        at com.android.internal.policy.PhoneWindow.setContentView(PhoneWindow.java:420)
        at android.app.Activity.setContentView(Activity.java:2771)
        at com.example.fragmentdemo.MainActivity.onCreate(MainActivity.java:11)
        at android.app.Activity.performCreate(Activity.java:7136)
        at android.app.Activity.performCreate(Activity.java:7127)
        at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1271)
        at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2893)
        at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:3048)
        at android.app.servertransaction.LaunchActivityItem.execute(LaunchActivityItem.java:78)
        at android.app.servertransaction.TransactionExecutor.executeCallbacks(TransactionExecutor.java:108)
        at android.app.servertransaction.TransactionExecutor.execute(TransactionExecutor.java:68)
        at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1808)
        at android.os.Handler.dispatchMessage(Handler.java:106)
        at android.os.Looper.loop(Looper.java:193)
        at android.app.ActivityThread.main(ActivityThread.java:6669)
        at java.lang.reflect.Method.invoke(Native Method)
        at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:493)
        at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:858)
     Caused by: java.lang.ClassCastException
        at android.app.Fragment.instantiate(Fragment.java:526) 
        at android.app.FragmentContainer.instantiate(FragmentContainer.java:53) 
        at android.app.FragmentManagerImpl.onCreateView(FragmentManager.java:3547) 
        at android.app.FragmentController.onCreateView(FragmentController.java:102) 
        at android.app.Activity.onCreateView(Activity.java:6323) 
        at android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:780) 
        at android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:730) 
        at android.view.LayoutInflater.rInflate(LayoutInflater.java:863) 
        at android.view.LayoutInflater.rInflateChildren(LayoutInflater.java:824) 
        at android.view.LayoutInflater.inflate(LayoutInflater.java:515) 
        at android.view.LayoutInflater.inflate(LayoutInflater.java:423) 
        at android.view.LayoutInflater.inflate(LayoutInflater.java:374) 
        at com.android.internal.policy.PhoneWindow.setContentView(PhoneWindow.java:420) 
        at android.app.Activity.setContentView(Activity.java:2771) 
        at com.example.fragmentdemo.MainActivity.onCreate(MainActivity.java:11) 
        at android.app.Activity.performCreate(Activity.java:7136) 
        at android.app.Activity.performCreate(Activity.java:7127) 
        at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1271) 
        at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2893) 
        at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:3048) 
        at android.app.servertransaction.LaunchActivityItem.execute(LaunchActivityItem.java:78) 
        at android.app.servertransaction.TransactionExecutor.executeCallbacks(TransactionExecutor.java:108) 
        at android.app.servertransaction.TransactionExecutor.execute(TransactionExecutor.java:68) 
        at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1808) 
        at android.os.Handler.dispatchMessage(Handler.java:106) 
        at android.os.Looper.loop(Looper.java:193) 
        at android.app.ActivityThread.main(ActivityThread.java:6669) 
        at java.lang.reflect.Method.invoke(Native Method) 
        at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:493) 
        at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:858) 

我正在使用 Android Studio 4.1.1

如何在模拟器中正确运行该应用程序?

fragment_top_section.xml你必须提供id android:id="@+id/top_fragment"

同样,在fragment_bottom_image.xml你必须提供id android:id="@+id/bottom_fragment"

然后,在MainActivity.java中,您必须添加以下导入语句 -

import androidx.fragment.app.FragmentManager;

onCreate(Bundle savedInstanceState)下,您必须添加以下代码 -

        final FragmentManager fragmentManager = getSupportFragmentManager();
        final TopSectionFragment topSectionFragment = new TopSectionFragment();
        fragmentManager.beginTransaction().replace(R.id.top_fragment, topSectionFragment);
        final BottomImageFragment bottomImageFragment = new BottomImageFragment();
        fragmentManager.beginTransaction().replace(R.id.bottom_fragment, bottomImageFragment);

注意:您的MainActivity必须扩展AppCompatActivity而不是Activity

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM