android - 使用 Proguard 时来源不明

标签 android proguard minify shrinkresources

如果我使用 Proguard(minifyEnabled trueshr​​inkResources true),我的崩溃报告会有点用处

这是 Proguard 的报告:

java.lang.NullPointerException: Attempt to invoke virtual method 'void android.widget.ProgressBar.setVisibility(int)' on a null object reference
    at xx.xxxx.xxx.xxxxx.xxxxxx.restoreViewAfterLoading(Unknown Source)
    at xx.xxxx.xxx.xxxxx.xxxxxx.newInstance(Unknown Source)
                                                     onCreateView
                                                     onViewCreated
                                                     access$000
    at xx.xxxx.xxx.xxxxx.xxxxxx$1.success(Unknown Source)
    at xx.xxxx.xxx.xxxxx.xxxxxx$1.success(Unknown Source)
    at retrofit.CallbackRunnable$1.run(Unknown Source)
    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:5254)
    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:903)
    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:698)

这是没有 Proguard 的正常报告:

java.lang.NullPointerException: Attempt to invoke virtual method 'void android.widget.ProgressBar.setVisibility(int)' on a null object reference
    at xx.xxxx.xxx.xxxxx.xxxxxx.restoreViewAfterLoading(xxxxxx.java:123)
    at xx.xxxx.xxx.xxxxx.xxxxxx.access$000(xxxxxx.java:26)
    at xx.xxxx.xxx.xxxxx.xxxxxx$1.success(xxxxxx.java:96)
    at xx.xxxx.xxx.xxxxx.xxxxxx$1.success(xxxxxx.java:92)
    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:135)
    at android.app.ActivityThread.main(ActivityThread.java:5254)
    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:903)
    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:698)

我可以通过 Proguard 获取行号吗?

最佳答案

看起来您在某个文件中的某个名为 restoreViewAfterLoading 的方法中有一个 NPE,其中 setVisibility 在某个文件的第 123 行附近的 ProgressBar(为 null)上被调用。这一切都发生在改造回调中。因此,我的第一个想法是在用户完成此 Activity/fragment 的情况下检查是否为 null。

为了获得更好的行号,将以下内容添加到您的混淆器配置中

# Preserve annotations, line numbers, and source file names
-keepattributes *Annotation*,SourceFile,LineNumberTable

这将在混淆的堆栈跟踪中保留行号。

HTH

关于android - 使用 Proguard 时来源不明,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30035021/

相关文章:

android - Camera.open() 返回 null

java - 从 SQLite 数据库中检索数据到 EditText

android - 通过 Android 中的 Intent 将参数传递给 BroadcastReceiver

Android:Proguard 的推荐配置是什么?

java - Proguard 不会查看嵌入式 jar 来进行引用查找

javascript - 为什么 minification + gzip 使文件大小比 gzip 更小

Android Studio 找不到任何与 come.google.maps 匹配的版本

java - Spring Boot 和 Proguard

java - ProGuard 导致应用程序延迟

java - 如何在 Java 中获得打印精美的 JSON 的紧凑/缩小形式?