android - NoSuchMethodError Lcom/google/gson/Gson;在改造响应
问题描述
所以,我的应用程序发布了将近一年而没有看到这个问题,现在它出现了。
即使现在,我的手机上的调试版本也没有这个问题。从 Android Studio 打开的任何模拟器都没有任何问题。然而,Google Developer Console 中发布前报告中的几乎每个模拟器在收到 Retrofit 响应时都会出现此 NoSuchMethodError 崩溃。
FATAL EXCEPTION: ControllerMessenger
Process: xxxxxxx, PID: 25090
java.lang.NoSuchMethodError: No direct method <init>(Lcom/google/gson/Gson;)V in class Lcom/google/gson/Gson$1; or its super classes (declaration of 'com.google.gson.Gson$1' appears in /data/app/com.google.android.apps.mtaas.crawler-1/base.apk)
at com.google.gson.Gson.doubleAdapter(Gson.java:278)
at com.google.gson.Gson.<init>(Gson.java:217)
at com.google.gson.Gson.<init>(Gson.java:174)
at retrofit2.converter.gson.GsonConverterFactory.create(GsonConverterFactory.java:42)
at xxxxxxx.MtbActivity.loadJSON(MtbActivity.java:149)
at xxxxxxx.MtbActivity.onCreate(MtbActivity.java:135)
at android.app.Activity.performCreate(Activity.java:6013)
at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1108)
at androidx.test.runner.MonitoringInstrumentation.callActivityOnCreate(MonitoringInstrumentation.java:215)
at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2359)
at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2466)
at android.app.ActivityThread.access$1200(ActivityThread.java:152)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1341)
at android.os.Handler.dispatchMessage(Handler.java:102)
at androidx.test.espresso.base.Interrogator.a(Interrogator.java:19)
at androidx.test.espresso.base.UiControllerImpl.a(UiControllerImpl.java:142)
at androidx.test.espresso.base.UiControllerImpl.a(UiControllerImpl.java:134)
at androidx.test.espresso.base.UiControllerImpl.a(UiControllerImpl.java:114)
at androidx.test.espresso.action.Tap$1.b(Tap.java:6)
at androidx.test.espresso.action.GeneralClickAction.perform(GeneralClickAction.java:22)
at androidx.test.espresso.ViewInteraction$SingleExecutionViewAction.perform(ViewInteraction.java:9)
at androidx.test.espresso.ViewInteraction.a(ViewInteraction.java:78)
at androidx.test.espresso.ViewInteraction.a(ViewInteraction.java:94)
at androidx.test.espresso.ViewInteraction$1.call(ViewInteraction.java:3)
at java.util.concurrent.FutureTask.run(FutureTask.java:237)
at android.os.Handler.handleCallback(Handler.java:739)
at android.os.Handler.dispatchMessage(Handler.java:95)
at android.os.Looper.loop(Looper.java:135)
at android.app.ActivityThread.main(ActivityThread.java:5538)
at java.lang.reflect.Method.invoke(Native Method)
at java.lang.reflect.Method.invoke(Method.java:372)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:960)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:755)
我试过的:
- 将 Retrofit 和 Gson 依赖项更新到最新版本。
- 使缓存无效并重新启动
implementation 'com.squareup.retrofit2:retrofit:2.4.0' implementation 'com.squareup.retrofit2:converter-gson:2.4.0'
解决方案
感谢彼得在这里
总结一下:
现有的爬虫是FUBAR。作为一种解决方法,您可以通过选择退出新发布的爬虫返回到以前版本的爬虫。
以下是选择退出的方法:
登录您的 Play 管理中心。选择一个应用程序。选择发布管理 > 发布前报告 > 设置。在“发布前报告版本”部分中,将退出开关向右移动,直到它变为蓝色。在此之后,启动报告再次正确显示。
推荐阅读
- java - 如何在java mysql中获取最后一个插入ID
- vue.js - 用户使用令牌身份验证登录后如何隐藏登录路由导航元素?
- excel - 如何根据空单元格在excel中进行线性插值
- javascript - 如何在imacros中按条件创建无限循环?
- python - 如何从受另一列约束的数据库中提取一列数据
- android - 在 Firebase-RealtimeDatabase 上使用什么规则让用户注册和登录?
- laravel - 解析错误:语法错误,意外的“?”
- python - 修剪列表中的最后一个字符
- django - 将列链接到静态子目录中的文件;django-tables2
- django-rest-framework - 在序列化器中重新定义一个字段