例如,下面的错误消息显示从GameController.java中的第435号行抛出的GameController.java:
java.lang.NullPointerException
at com.fuu.mahjong.game.GameController.boolean showHint(boolean)(GameController.java:435)
at com.fuu.mahjong.game.GameViewActivity.boolean onTouch(android.view.View,android.view.MotionEvent)(GameViewAct
ivity.java:1552)
at android.view.View.dispatchTouchEvent(View.java:7122)
at android.view.ViewGroup.dispatchTransformedTouchEvent(ViewGroup.java:2176)
...GameController.java中的第435号行是
clearCurrentSelections();clearCurrentSelections()是GameController中的一个私有方法,错误消息不显示clearCurrentSelections()中的跟踪信息,如果我将clearCurrentSelections()更改为public,则错误消息显示clearCurrentSelections()中的哪一行会导致NullPointerException。
在使用ProGuard之后,有任何方法在私有方法中显示跟踪信息吗?
发布于 2013-09-02 16:44:43
ProGuard的优化步骤可能包含了该方法。然后,虚拟机在堆栈跟踪中生成更少的行。如果要避免这种情况,可以禁用方法内联:
-optimizations !method/inlining/*在Dalvik虚拟机上,方法内联虽然提高了性能。
方法是否是私有的对于优化来说并不重要,除非您的配置显式地保留公共方法。
https://stackoverflow.com/questions/18562503
复制相似问题