1

奇妙なエラーのように思われるものが原因で、起動時にアプリケーションがクラッシュし続けます。以下の logcat と関連するレイアウトを含めましたが、ご覧のとおり、 class の class not found 例外によって引き起こされた inflate 例外がありますandroid.view.fragment。私は互換性フラグメントを使用していないため (アプリは ICS より前のバージョンをサポートしていません)、すべてがandroid.app.Fragment. 私が見つけることができた他のすべての投稿は、使用を提案してFragmentActivityいますが、サポート ライブラリを使用していないため、ここでは解決策ではありません。誰にも洞察力がありますか?

レイアウト ファイル:

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:ads="http://schemas.android.com/apk/lib/com.google.ads"
    xmlns:tools="http://schemas.android.com/tools"
    android:id="@+id/locations"
    android:layout_width="match_parent"
    android:layout_height="match_parent" >

    <!-- Some views here -->

    <!-- The line below is line 38 referenced in the LogCat -->
    <fragment
        android:id="@+id/ad_fragment"
        android:name="tenkiv.billing.AdFragment"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_alignParentBottom="true"
        tools:layout="@layout/ad_fragment_view" />

</RelativeLayout>

LogCat の出力:

FATAL EXCEPTION: main
java.lang.RuntimeException: Unable to start activity ComponentInfo{com.tenkiv.environment.application/com.tenkiv.environment.application.EnvironmentMainActivity}: android.view.InflateException: Binary XML file line #38: Error inflating class fragment
    at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2180)
    at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2230)
    at android.app.ActivityThread.access$600(ActivityThread.java:141)
    at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1234)
    at android.os.Handler.dispatchMessage(Handler.java:99)
    at android.os.Looper.loop(Looper.java:137)
    at android.app.ActivityThread.main(ActivityThread.java:5041)
    at java.lang.reflect.Method.invokeNative(Native Method)
    at java.lang.reflect.Method.invoke(Method.java:511)
    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:793)
    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:560)
    at dalvik.system.NativeStart.main(Native Method)
Caused by: android.view.InflateException: Binary XML file line #38: Error inflating class fragment
    at android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:698)
    at android.view.LayoutInflater.rInflate(LayoutInflater.java:746)
    at android.view.LayoutInflater.inflate(LayoutInflater.java:489)
    at android.view.LayoutInflater.inflate(LayoutInflater.java:396)
    at android.view.LayoutInflater.inflate(LayoutInflater.java:352)
    at com.slidingmenu.lib.SlidingMenu.setMenu(SlidingMenu.java:384)
    at com.tenkiv.environment.application.EnvironmentMainActivity.onCreate(EnvironmentMainActivity.java:335)
    at android.app.Activity.performCreate(Activity.java:5104)
    at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1080)
    at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2144)
    ... 11 more
Caused by: java.lang.ClassNotFoundException: Didn't find class "android.view.fragment" on path: /data/app/com.tenkiv.environment.application-2.apk
    at dalvik.system.BaseDexClassLoader.findClass(BaseDexClassLoader.java:65)
    at java.lang.ClassLoader.loadClass(ClassLoader.java:501)
    at java.lang.ClassLoader.loadClass(ClassLoader.java:461)
    at android.view.LayoutInflater.createView(LayoutInflater.java:552)
    at android.view.LayoutInflater.onCreateView(LayoutInflater.java:643)
    at com.android.internal.policy.impl.PhoneLayoutInflater.onCreateView(PhoneLayoutInflater.java:66)
    at android.view.LayoutInflater.onCreateView(LayoutInflater.java:660)
    at android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:685)
    ... 20 more
4

3 に答える 3

1

このように完全修飾名を付けてみてもわかりません

 <fragment android:id="@+id/fragmentDetails" 
android:layout_height="fill_parent" 
android:layout_width="fill_parent" 
class="tenkiv.billing.AdFragment"/>
于 2013-02-26T17:59:38.370 に答える
0

この問題は、タイプミスや奇妙な非表示文字が xml タグに挿入されるなどのばかげたことによって引き起こされる可能性があります。私の場合、原因は「fragment」開始タグのタイプミスでした。代わりに「frsgment」があり、もちろん Android Studio はフラグを立てませんでした。理解するのにしばらく時間がかかりました。良くない!

于 2015-11-23T20:11:56.587 に答える
0

FragmentActivity クラスで、スーパー クラスから onCreate メソッドも呼び出していることを確認してください。

protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
....
}
于 2013-06-05T10:28:46.677 に答える