Toast.makeText出现“Error inflating class Textview”异常

12

我应用程序中每个Toast.makeText都会给我提供类似于这样的堆栈跟踪:

/AndroidRuntime: FATAL EXCEPTION: main
Process: com.myapp.application, PID: 8843
android.view.InflateException: Binary XML file line #27: Binary XML file line #27: Error inflating class TextView
    at android.view.LayoutInflater.inflate(LayoutInflater.java:539)
    at android.view.LayoutInflater.inflate(LayoutInflater.java:423)
    at android.view.LayoutInflater.inflate(LayoutInflater.java:374)
    at android.widget.Toast.makeText(Toast.java:263)
    at com.myapp.application.activities.ReportActivity$5.success(ReportActivity.java:240)
    at com.myapp.application.activities.ReportActivity$5.success(ReportActivity.java:236)
    at retrofit.CallbackRunnable$1.run(CallbackRunnable.java:45)
    at android.os.Handler.handleCallback(Handler.java:739)
    at android.os.Handler.dispatchMessage(Handler.java:95)
    at android.os.Looper.loop(Looper.java:148)
    at android.app.ActivityThread.main(ActivityThread.java:5417)
    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: android.view.InflateException: Binary XML file line #27: Error inflating class TextView
    at android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:782)
    at android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:704)
    at android.view.LayoutInflater.rInflate(LayoutInflater.java:835)
    at android.view.LayoutInflater.rInflateChildren(LayoutInflater.java:798)
    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 android.widget.Toast.makeText(Toast.java:263) 
    at com.myapp.application.activities.ReportActivity$5.success(ReportActivity.java:240) 
    at com.myapp.application.activities.ReportActivity$5.success(ReportActivity.java:236) 
    at retrofit.CallbackRunnable$1.run(CallbackRunnable.java:45) 
    at android.os.Handler.handleCallback(Handler.java:739) 
    at android.os.Handler.dispatchMessage(Handler.java:95) 
    at android.os.Looper.loop(Looper.java:148) 
    at android.app.ActivityThread.main(ActivityThread.java:5417) 
    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.ArrayIndexOutOfBoundsException: length=16; index=1191
    at android.content.res.StringBlock.get(StringBlock.java:65)
    at android.content.res.XmlBlock$Parser.getPooledString(XmlBlock.java:458)
    at android.content.res.TypedArray.loadStringValueAt(TypedArray.java:1151)
    at android.content.res.TypedArray.getString(TypedArray.java:195)
    at android.support.v7.widget.TintTypedArray.getString(TintTypedArray.java:142)
    at android.support.v7.widget.AppCompatTextHelper.updateTypefaceAndStyle(AppCompatTextHelper.java:243)
    at android.support.v7.widget.AppCompatTextHelper.loadFromAttributes(AppCompatTextHelper.java:165)
    at android.support.v7.widget.AppCompatTextHelperV17.loadFromAttributes(AppCompatTextHelperV17.java:38)
    at android.support.v7.widget.AppCompatTextView.<init>(AppCompatTextView.java:80)
    at android.support.v7.widget.AppCompatTextView.<init>(AppCompatTextView.java:70)
    at android.support.v7.app.AppCompatViewInflater.createView(AppCompatViewInflater.java:103)
    at android.support.v7.app.AppCompatDelegateImplV9.createView(AppCompatDelegateImplV9.java:1016)
    at android.support.v7.app.AppCompatDelegateImplV9.onCreateView(AppCompatDelegateImplV9.java:1073)

以下是一些导致其失败的 Toast.makeText 调用示例:

Toast.makeText(ReportActivity.this, "已报告" + reportType, Toast.LENGTH_SHORT).show();

Toast.makeText(this, R.string.network_unavailable, Toast.LENGTH_SHORT).show();

一切都始于我们升级 Gradle 库并开始使用这些版本。

compileSdkVersion 27
buildToolsVersion '27.0.1'

1
add your code please - elgringo
@elgringo,引起问题的代码是Toast.makeText。我认为通过删除所有的android:fontFamily条目,我已经修复了它。 - Walker
如果您不发布您的代码,我们将无法帮助您。Toast.makeText没有问题。但是如果您已经解决了它,现在就没有错误了 :) - elgringo
@elgringo 不确定我有100多个文件时应该发布哪些代码。我认为引起问题的那一行会引发一些想法,以找出它引起问题的原因。但是我现在认为问题已经解决了!我会发布答案。 - Walker
3个回答

49

这个 bug 显然出现在使用支持库 26+,API 版本为 25 及以下版本,并且据说在 Oreo 中已经修复。

参见:https://issuetracker.google.com/issues/64053344

在我的情况下,解决方法是更改默认主题中定义的 fontFamily,将 sans-serif-light 提取到字符串资源中,即从以下内容:

<style name="AppCompatTheme" parent="android:...">
  <item name="fontFamily">sans-serif-light</item>
</style>

变为这样:

   <style name="AppCompatTheme" parent="android:...">
     <item name="fontFamily">@string/default_font</item>
   </style>

在我的strings.xml文件中:

   <string name="default_font" translatable="false">sans-serif-light</string>

2
大佬,你救了我的一天啊!所有安卓6/7用户都崩溃的问题竟然这么奇怪... - ZhouX

4

我的Toast调用使用了getBaseContext()。我只是将其更改为getApplicationContext()以解决问题。


2

我通过全局搜索fontFamily并删除条目,解决了应用程序中所有Toast.makeText的崩溃问题。

似乎字体系列被定义了,而新的构建工具和SDK不喜欢它。


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