使用 Proguard 时来源不明
Unknown Source when I use Proguard
如果我使用 Proguard(minifyEnabled true
和 shrinkResources 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[=10=]0
at xx.xxxx.xxx.xxxxx.xxxxxx.success(Unknown Source)
at xx.xxxx.xxx.xxxxx.xxxxxx.success(Unknown Source)
at retrofit.CallbackRunnable.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[=11=]0(xxxxxx.java:26)
at xx.xxxx.xxx.xxxxx.xxxxxx.success(xxxxxx.java:96)
at xx.xxxx.xxx.xxxxx.xxxxxx.success(xxxxxx.java:92)
at retrofit.CallbackRunnable.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(为空)上被调用。这一切都发生在改造回调中。所以我的第一个想法是在用户完成此 activity/fragment.
的情况下检查 null
为了获得更好的行编号,请将以下内容添加到您的混淆器配置中
# Preserve annotations, line numbers, and source file names
-keepattributes *Annotation*,SourceFile,LineNumberTable
这将在混淆的堆栈跟踪中保留行号。
HTH
如果我使用 Proguard(minifyEnabled true
和 shrinkResources 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[=10=]0
at xx.xxxx.xxx.xxxxx.xxxxxx.success(Unknown Source)
at xx.xxxx.xxx.xxxxx.xxxxxx.success(Unknown Source)
at retrofit.CallbackRunnable.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[=11=]0(xxxxxx.java:26)
at xx.xxxx.xxx.xxxxx.xxxxxx.success(xxxxxx.java:96)
at xx.xxxx.xxx.xxxxx.xxxxxx.success(xxxxxx.java:92)
at retrofit.CallbackRunnable.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(为空)上被调用。这一切都发生在改造回调中。所以我的第一个想法是在用户完成此 activity/fragment.
为了获得更好的行编号,请将以下内容添加到您的混淆器配置中
# Preserve annotations, line numbers, and source file names
-keepattributes *Annotation*,SourceFile,LineNumberTable
这将在混淆的堆栈跟踪中保留行号。
HTH