Error inflating class com,2024年最新2024Golang高级面试题汇总解答

17 阅读3分钟

at android.view.LayoutInflater.createView(LayoutInflater.java:647)

at android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:790)

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 androidx.appcompat.app.AppCompatDelegateImpl.setContentView(AppCompatDelegateImpl.java:9)

at androidx.appcompat.app.AppCompatActivity.setContentView(AppCompatActivity.java:1)

at com.androidwind.base.ui.QuickActivity.setContentView(QuickActivity.java:15)

at com.androidwind.base.ui.QuickActivity.onCreate(QuickActivity.java:8)

at android.app.Activity.performCreate(Activity.java:7326)

at android.app.Activity.performCreate(Activity.java:7317)

at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1271)

at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:3072)

at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:3235)

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:1926)

at android.os.Handler.dispatchMessage(Handler.java:106)

at android.os.Looper.loop(Looper.java:214)

at android.app.ActivityThread.main(ActivityThread.java:6990)

at java.lang.reflect.Method.invoke(Native Method)

at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:494)

at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1445)

Caused by: java.lang.NoSuchMethodError: No static method asAttributeSet(Lh/e/a/a;)Landroid/util/AttributeSet; in class Landroid/util/Xml; or its super classes (declaration of 'android.util.Xml' appears in /system/framework/framework.jar!classes2.dex)

场景还原

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

debug环境下没有问题,但是在release环境下就出错。

NavigationView是从com.google.android.material包下引入的。

解决过程

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

首先想到的是会不会因为开启了混淆导致的?

在proguard-rules.pro文件中看到已经对androidx版本进行了适配:

androidx的混淆

-keep class com.google.android.material.** {*;}

-keep class androidx.** {*;}

-keep public class * extends androidx.**

-keep interface androidx.** {*;}

-dontwarn com.google.android.material.**

-dontnote com.google.android.material.**

-dontwarn androidx.**

接着想到是不是com.google.android.material包的版本较低?

当前版本是1.1.0-alpha09,看到最新版本是1.2.0-alpha03,于是改成最新版本,重新build后发现问题仍然存在,初步排除应该不是这个原因导致的。

最后在网上搜索的时候发现有人也遇到类似的问题,参考:

www.it1me.com/it-answers?…

其中有人提到:

在这里插入图片描述

于是将app:srcCompat改为android:src,这样问题解决了么?

然而并没有。。。

接着往下看:

在这里插入图片描述

其中说到了drawable文件夹中的内容要保持一致,

突然想起来前些时间顺手把drawable-v24文件夹给删了,理论上来说因该都会用到drawable文件夹内的东西吧?难道这两个文件夹内的东西还不一致?

看了一下,果然,drawable-v24文件夹中有一个ic_launcher_foreground.xml文件,但是在drawable文件夹中却没有,于是将ic_launcher_foreground.xml文件复制到drawable文件夹内。

你以为这样就结束了么?运行以后仍然崩溃。

回过头,我们看一下log日志,最开始的地方提示:

Caused by: java.lang.NoSuchMethodError: No static method asAttributeSet(Lh/e/a/a;)Landroid/util/AttributeSet; in class Landroid/util/Xml; or its super classes (declaration of ‘android.util.Xml’ appears in /system/framework/framework.jar!classes2.dex)

原来是混淆过后找不到文件了,都变成h/e/a/a之类的。

这类问题网上也比较多:

www.ojit.com/article/351…

在混淆文件中加入如下代码即可:

-dontwarn org.xmlpull.v1.XmlPullParser -dontwarn org.xmlpull.v1.XmlSerializer -keep class org.xmlpull.v1.* {*;}

img img

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化的资料的朋友,可以添加戳这里获取

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!