Proguard: исключение NullPointerException в ArrayAdapter.createViewFromResource без каких-либо моих классов в трассировке стека - PullRequest
0 голосов
/ 26 февраля 2020

Мое приложение запускается без проблем. Но пока я вхожу в систему, и следующее действие собирается запустить приложение, происходит сбой со следующим исключением:

java.lang.NullPointerException: Attempt to invoke virtual method 'java.lang.String java.lang.Object.toString()' on a null object reference
    at android.widget.ArrayAdapter.createViewFromResource(ArrayAdapter.java:453)
    at android.widget.ArrayAdapter.getView(ArrayAdapter.java:415)
    at android.widget.AbsSpinner.onMeasure(AbsSpinner.java:204)
    at android.widget.Spinner.onMeasure(Spinner.java:602)
    at android.view.View.measure(View.java:23169)
    at android.view.ViewGroup.measureChildWithMargins(ViewGroup.java:6749)
    at android.widget.LinearLayout.measureChildBeforeLayout(LinearLayout.java:1535)
    at android.widget.LinearLayout.measureHorizontal(LinearLayout.java:1187)
    at android.widget.LinearLayout.onMeasure(LinearLayout.java:706)
    at android.view.View.measure(View.java:23169)
    at android.widget.LinearLayout.measureHorizontal(LinearLayout.java:1168)
    at android.widget.LinearLayout.onMeasure(LinearLayout.java:706)
    at android.view.View.measure(View.java:23169)
    at android.view.ViewGroup.measureChildWithMargins(ViewGroup.java:6749)
    at android.widget.LinearLayout.measureChildBeforeLayout(LinearLayout.java:1535)
    at android.widget.LinearLayout.measureVertical(LinearLayout.java:825)
    at android.widget.LinearLayout.onMeasure(LinearLayout.java:704)
    at android.view.View.measure(View.java:23169)
    at android.widget.RelativeLayout.measureChildHorizontal(RelativeLayout.java:715)
    at android.widget.RelativeLayout.onMeasure(RelativeLayout.java:461)
    at android.view.View.measure(View.java:23169)
    at android.view.ViewGroup.measureChildWithMargins(ViewGroup.java:6749)
    at android.widget.LinearLayout.measureChildBeforeLayout(LinearLayout.java:1535)
    at android.widget.LinearLayout.measureVertical(LinearLayout.java:825)
    at android.widget.LinearLayout.onMeasure(LinearLayout.java:704)
    at android.view.View.measure(View.java:23169)
    at android.view.ViewGroup.measureChildWithMargins(ViewGroup.java:6749)
    at android.widget.FrameLayout.onMeasure(FrameLayout.java:185)
    at android.view.View.measure(View.java:23169)
    at android.view.ViewGroup.measureChildWithMargins(ViewGroup.java:6749)
    at com.android.internal.widget.ActionBarOverlayLayout.onMeasure(ActionBarOverlayLayout.java:461)
    at android.view.View.measure(View.java:23169)
    at android.view.ViewGroup.measureChildWithMargins(ViewGroup.java:6749)
    at android.widget.FrameLayout.onMeasure(FrameLayout.java:185)
    at com.android.internal.policy.DecorView.onMeasure(DecorView.java:716)
    at android.view.View.measure(View.java:23169)
    at android.view.ViewRootImpl.performMeasure(ViewRootImpl.java:2718)
    at android.view.ViewRootImpl.measureHierarchy(ViewRootImpl.java:1572)
    at android.view.ViewRootImpl.performTraversals(ViewRootImpl.java:1855)
    at android.view.ViewRootImpl.doTraversal(ViewRootImpl.java:1460)
    at android.view.ViewRootImpl$TraversalRunnable.run(ViewRootImpl.java:7183)
    at android.view.Choreographer$CallbackRecord.run(Choreographer.java:949)
    at android.view.Choreographer.doCallbacks(Choreographer.java:761)
    at android.view.Choreographer.doFrame(Choreographer.java:696)
    at android.view.Choreographer$FrameDisplayEventReceiver.run(Choreographer.java:935)
    at android.os.Handler.handleCallback(Handler.java:873)
    at android.os.Handler.dispatchMessage(Handler.java:99)
    at android.os.Looper.loop(Looper.java:193)
    at android.app.ActivityThread.main(ActivityThread.java:6669)
    at java.lang.reflect.Method.invoke(Native Method)
    at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:493)
    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:858)

Меня удивляет то, что ни один из моих классов или внешней библиотеки не появляется. Если я сохраню весь свой пакет, следующее действие начнется успешно. Но тогда мне тоже не нужно использовать запутывание. Что тоже странно: если я сохраню весь свой пакет, он будет работать нормально. Но если я оставлю два подпакета (package.name.technical & package.name.functional), это не сработает.

Я сохраню много вещей View, которые я нашел в inte rnet. Например:

-keep class android.widget.AutoCompleteTextView {*;}
-keep class android.widget.Spinner {*;}
-keep class android.widget.ArrayAdapter {*;}
-keep public class * extends android.widget.AdapterView {*;}
-keep public class * extends android.widget.Adapter {*;}
-keep public class * extends android.widget.BaseAdapter {*;}
-keep public class * extends android.view.View {
    public <init>(android.content.Context);
    public <init>(android.content.Context, android.util.AttributeSet);
    public <init>(android.content.Context, android.util.AttributeSet, int);
    public void set*(...);
}

Я также сохраняю действие, которое должно начаться.

"shrinkResources" НЕ включен в build.gradle.

Кто-нибудь знает, почему ? Я действительно отчаялся и не знаю, что делать.

1 Ответ

2 голосов
/ 26 февраля 2020

Интересная тема! Давайте немного углубимся в это.

Во-первых, что такое null? Ну, есть только один toString() вызов в ArrayAdapter.createViewFromResource, так что это должно быть так.

Это элемент, который возвращается с getItem(position) несколькими строками вверх.

getItem прост: он просто возвращает элемент из List объектов, переданных в конструктор.

Таким образом, ваша проблема в том, что что-то в вашей обфускации Proguard вызывает у вас null предмет из List передан в один из ваших ArrayAdapter s. Возможно, проблема раздувания моделей с помощью Gson или другой десериализации на основе отражений?

...