android.view.InflateException: 二进制XML文件第12行:解析<unknown>类时出错。

164

我收到了许多类似于主题中显示的错误。这些错误似乎是偶然发生的,我无法重现它们。从堆栈中,我可以了解到这种错误可能会导致我的不同布局资源出现问题。XML行也随之变化。

有人能解释一下为什么会出现这种错误吗?我该怎么解决这个问题?

堆栈

=============================================================

com.fsp.android.f generated the following exception:
java.lang.RuntimeException: Unable to start activity ComponentInfo{com.fsp.android.f/com.life360.android.ui.tour.TourActivity}: android.view.InflateException: Binary XML file line #12: Error inflating class <unknown>

--------- Stack trace ---------
1. android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2649)
2. android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2674)
3. android.app.ActivityThread.access$2200(ActivityThread.java:131)
4. android.app.ActivityThread$H.handleMessage(ActivityThread.java:1975)
5. android.os.Handler.dispatchMessage(Handler.java:99)
6. android.os.Looper.loop(Looper.java:123)
7. android.app.ActivityThread.main(ActivityThread.java:4702)
8. java.lang.reflect.Method.invokeNative(Native Method)
9. java.lang.reflect.Method.invoke(Method.java:521)
10. com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:860)
11. com.android.internal.os.ZygoteInit.main(ZygoteInit.java:618)
12. dalvik.system.NativeStart.main(Native Method)
-------------------------------

----------- Cause -----------
android.view.InflateException: Binary XML file line #12: Error inflating class <unknown>

1. android.view.LayoutInflater.createView(LayoutInflater.java:513)
2. com.android.internal.policy.impl.PhoneLayoutInflater.onCreateView(PhoneLayoutInflater.java:56)
3. android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:563)
4. android.view.LayoutInflater.rInflate(LayoutInflater.java:618)
5. android.view.LayoutInflater.rInflate(LayoutInflater.java:621)
6. android.view.LayoutInflater.inflate(LayoutInflater.java:382)
7. android.view.LayoutInflater.inflate(LayoutInflater.java:320)
8. android.view.LayoutInflater.inflate(LayoutInflater.java:276)
9. com.android.internal.policy.impl.PhoneWindow.setContentView(PhoneWindow.java:208)
10. android.app.Activity.setContentView(Activity.java:1629)
11. com.solvek.sample.ui.BaseActivity.onCreate(BaseActivity.java:23)
12. com.solvek.sample.ui.tour.TourActivity.onCreate(TourActivity.java:161)
13. android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1047)
14. android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2587)
15. android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2674)
16. android.app.ActivityThread.access$2200(ActivityThread.java:131)
17. android.app.ActivityThread$H.handleMessage(ActivityThread.java:1975)
18. android.os.Handler.dispatchMessage(Handler.java:99)
19. android.os.Looper.loop(Looper.java:123)
20. android.app.ActivityThread.main(ActivityThread.java:4702)
21. java.lang.reflect.Method.invokeNative(Native Method)
22. java.lang.reflect.Method.invoke(Method.java:521)
23. com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:860)
24. com.android.internal.os.ZygoteInit.main(ZygoteInit.java:618)
25. dalvik.system.NativeStart.main(Native Method)
-----------------------------

-------- Environment --------
Time =2010-12-20 08:27:35 AM
Device =tmobile/htc_espresso/espresso/espresso:2.1-update1/ERE27/216830:user/release-keys
Make =HTC
Model =T-Mobile myTouch 3G Slide
Product =htc_espresso
App =com.fsp.android.f, version 2.0.9 (build 1232)

这是一个XML的结果,但是其他的XML也可能会出现这样的错误。

<?xml version="1.0" encoding="utf-8"?>
<merge xmlns:android="http://schemas.android.com/apk/res/android">
    <ViewFlipper android:layout_gravity="fill" android:id="@+id/flipper" android:layout_height="fill_parent" android:layout_width="fill_parent">
        <ImageView android:scaleType="fitXY" android:layout_width="fill_parent" android:layout_height="fill_parent" android:src="@drawable/tour_1"/>
        <ImageView android:scaleType="fitXY" android:layout_width="fill_parent" android:layout_height="fill_parent" android:src="@drawable/tour_2"/>
        <ImageView android:scaleType="fitXY" android:layout_width="fill_parent" android:layout_height="fill_parent" android:src="@drawable/tour_3"/>
        <ImageView android:scaleType="fitXY" android:layout_width="fill_parent" android:layout_height="fill_parent" android:src="@drawable/tour_4"/>
        <ImageView android:scaleType="fitXY" android:layout_width="fill_parent" android:layout_height="fill_parent" android:src="@drawable/tour_5"/>
        <ImageView android:scaleType="fitXY" android:layout_width="fill_parent" android:layout_height="fill_parent" android:src="@drawable/tour_6"/>
        <ImageView android:scaleType="fitXY" android:layout_width="fill_parent" android:layout_height="fill_parent" android:src="@drawable/tour_7"/>
        <ImageView android:scaleType="fitXY" android:layout_width="fill_parent" android:layout_height="fill_parent" android:src="@drawable/tour_8"/>
        <ImageView android:scaleType="fitXY" android:layout_width="fill_parent" android:layout_height="fill_parent" android:src="@drawable/tour_9"/>
        <ImageView android:scaleType="fitXY" android:layout_width="fill_parent" android:layout_height="fill_parent" android:src="@drawable/tour_10"/>
        <ImageView android:scaleType="fitXY" android:layout_width="fill_parent" android:layout_height="fill_parent" android:src="@drawable/tour_11"/>
    </ViewFlipper>

    <LinearLayout android:id="@+id/exit_bar" android:layout_gravity="top" android:layout_width="fill_parent" android:layout_height="wrap_content" android:background="@drawable/blue_bar" android:visibility="invisible">
        <Button android:background="@drawable/orange_btn" android:layout_height="wrap_content" android:layout_width="wrap_content" android:layout_gravity="center" android:textStyle="bold" android:textColor="#000000" android:shadowColor="#ffffff" android:shadowRadius="1.6" android:shadowDx="1.5" android:shadowDy="1.3" android:id="@+id/exit_tour_btn" android:text="Exit" android:layout_marginLeft="20dip"/>
        <TextView android:layout_height="wrap_content" android:textColor="#ffffff" android:layout_gravity="center" android:layout_width="110dip" android:layout_marginLeft="20dip" android:textSize="16dip" android:textStyle="bold" android:text="Life360 Tour"/>

    </LinearLayout>

    <Button style="@style/BlueBtn" android:text="Continue" android:layout_marginTop="40dip" android:id="@+id/continue_btn" android:visibility="gone" android:layout_height="wrap_content" android:layout_width="wrap_content" android:layout_gravity="center" />

    <FrameLayout android:id="@+id/bottom_bar" android:layout_gravity="bottom" android:layout_width="fill_parent" android:layout_height="wrap_content" android:background="@drawable/blue_bar" android:visibility="invisible">
        <ImageView android:layout_height="wrap_content" android:layout_width="wrap_content" android:id="@+id/left" android:layout_gravity="left|center" android:background="@drawable/tour_left" android:layout_marginLeft="10dip"/>
        <ImageView android:layout_height="wrap_content" android:layout_width="wrap_content" android:id="@+id/right" android:layout_gravity="right|center" android:background="@drawable/tour_right" android:layout_marginRight="10dip"/>               
    </FrameLayout>
</merge>

检查一下这个链接,它对我很有帮助!http://stackoverflow.com/questions/9480972/android-tablelayout-error - user1974235
33个回答

5
对我来说,错误信息在日志cat中实际上是不足的,因此这就是我为了找出问题原因所做的事情:
(在日志cat错误消息中,它说错误发生在我的HomeFragment.java中膨胀特定的布局)
1. 我在布局膨胀之前设置了断点 2. 我以调试模式运行应用程序,直到达到特定的断点 3. 我用光标选中了带有表达式的行,并运行了“评估表达式”:
- 运行>评估表达式或alt-F8
4. 结果向我展示了更多关于问题来源的信息,在我的情况下,是一个使用tools:targetApi="lollipop"的可绘制文件(该错误仅在旧设备上发生)。

谢谢!这帮助我找到了问题! - Sergey Stasishin

5

对我来说,我的问题在于:

android:background="?attr/selectableItemBackground"

对于一个LinearLayout的背景,一旦我去掉它,测试就通过了。


我使用了ConstraintLayout,并在其中使用了background标签。删除该行代码解决了我的问题,谢谢! - baskInEminence

4
这个链接或许能帮到您。请检查您的清单文件是否有问题。如果可以再次出现此错误,请发布完整的堆栈跟踪,以便我们看到实际的错误是什么。
编辑:我相信您已经检查过了,但是TourActivity布局XML文件的第12行是什么?

我已经阅读了这个问题。这不是我的情况(至少我看不到)。在问题中添加堆栈。 - Solvek
更新的答案,你能发布XML吗?如果可以的话,请发布整个XML,如果不是太大的话。 - Kevin Coppock
将初始问题中添加XML - Solvek
哎呀,很遗憾我没有使用合并或ViewFlipper的经验...所有出现这种情况的XML文件都使用合并或ViewFlipper吗? - Kevin Coppock
没有其他文件合并翻转器,但仍然存在相同的问题。 - Solvek
有时清单中特定活动的主题设置可能会引起问题。这就是我遇到的情况。 - Nick.D

3
  • 我只是解决了这个问题,只需从drawable(v24)中删除您的图像,然后将其粘贴到drawable文件夹中,这对我有效。


好的,谢谢您使它更加突出和清晰。 - Sharan

3

我知道这是一个已解决的问题,但我没有遇到过我所面临的原因。

问题在于Android Studio将我的可绘制对象放置在 /drawable-V24 中,而我的模拟器是API 23。因此,它最终找不到它。

解决办法是将所有可绘制对象移动到 /drawable 文件夹中(不要加上-24)。


我也有同样的情况。 - Rafael

3

您应该将图像文件从“drawable-24”文件夹复制到“drawable”文件夹中。


2

通过将所有可绘制项从drawable-v24移动到drawable中解决了这个问题。


2

我刚刚遇到了这个问题,并设法找出了原因。在我的值中引用了一个导致问题的颜色。所以手动定义它,而不是使用下拉建议中的一个。然后它就起作用了!


1
同样的,我收到了这个错误,因为我的res/values/colors.xml文件中缺少一种颜色。我们有一个定义好的工具栏颜色是空着的:<color name="toolbar_background_color"></color>。我们使用一个品牌文件,每个客户的文件都不同。结果证明,在另一个生成该文件的仓库中存在一个 bug。尽管如此,缺失的颜色代码是罪魁祸首。 - petestmart

2
我遇到了同样的错误,我将我的可绘制资源从文件夹drawable-mdpi移动到文件夹drawable中解决了问题。花了我一些时间才意识到这一点,因为在Eclipse中一切都运行得很完美,而在Android Studio中我遇到了这些难看的运行时错误。
编辑说明: 如果你正在从Eclipse迁移到Android Studio,并且你的项目来自Eclipse,可能会出现这种情况,请注意,在Android Studio中有些事情与Eclipse有所不同。

2
在我的情况下,当我使用浮动操作按钮并设置android:backgroundTint="#000"时,会出现这个错误。那么,只需不设置backgroundTint,问题就解决了。 希望对您有所帮助。

谢谢,这确实是我的问题。需要使用 app:backgroundTint 而不是 android:backgroundTint - Drago

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接