gpt4 book ai didi

java - 奇怪的NPE : primitive field null inside instance method

转载 作者:行者123 更新时间:2023-12-02 01:04:54 24 4
gpt4 key购买 nike

我遇到了一个奇怪的 NPE,其堆栈跟踪如下:

Fatal Exception: java.lang.NullPointerException: Attempt to read from field 'int com.foo.gvpclient.x.c' on a null object reference
at com.foo.gvpclient.GVPConfiguration.getDeviceTypeAsString(GVPConfiguration.java:507)
at com.foo.gvpclient.request.uniapi.authentication.LoginAnonymousRequest.<init>(LoginAnonymousRequest.java:39)
at com.foo.bar.analytics.managers.AnalyticsManager.sendEventsBatchAsAnonymous(AnalyticsManager.java:489)
at com.foo.bar.analytics.managers.AnalyticsManager.addEvent(AnalyticsManager.java:324)
at com.foo.bar.analytics.managers.AnalyticsManager.onBrowseEvent(AnalyticsManager.java:266)
at com.foo.bar.analytics.managers.AnalyticsManager.onBrowseEvent(AnalyticsManager.java:231)
at com.foo.bar.analytics.managers.AnalyticsManager.onBrowseEvent(AnalyticsManager.java:711)
at com.foo.bar.login.activities.LoginActivity.register(LoginActivity.java:469)
at com.foo.bar.login.activities.LoginActivity.access$register(LoginActivity.java:51)
at com.foo.bar.login.activities.LoginActivity$onCreate$$inlined$apply$lambda$1.onClick(LoginActivity.java:123)
at android.view.View.performClick(View.java:7339)
at android.widget.TextView.performClick(TextView.java:14221)
at android.view.View.performClickInternal(View.java:7305)
at android.view.View.access$3200(View.java:846)
at android.view.View$PerformClick.run(View.java:27787)
at android.os.Handler.handleCallback(Handler.java:873)
at android.os.Handler.dispatchMessage(Handler.java:99)
at android.os.Looper.loop(Looper.java:214)
at android.app.ActivityThread.main(ActivityThread.java:7076)
at java.lang.reflect.Method.invoke(Method.java)
at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:493)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:965)

这是getDeviceTypeAsString()方法:

public String getDeviceTypeAsString() {
return String.valueOf(this.mDeviceType);
}

其中 mDeviceType 声明为

private int mDeviceType;

如果我错了,请纠正我,但这里没有任何内容可以为空。

为了完整起见,从这里调用该方法:

public LoginAnonymousRequest(GVPConfiguration gvpConfig) {
super(gvpConfig);
// More unrelated stuff
this.mQueryStringParams.put("deviceType", this.mGvpConfig.getDeviceTypeAsString());
}

再次,如果我错了,请纠正我,但如果上面的构造函数中的 gvpConfig 为 null,那么 NPE 将在 this.mGvpConfig.getDeviceTypeAsString() 处抛出> 而不是在方法本身内部。

那么是什么导致了这个 NPE 呢?会不会和代码混淆有关?

最佳答案

这不是混淆,而是通过 proguard 或 r8 等相同工具完成的优化。

基本上,简单的访问器被优化为调用者中的内联,实际上调用站点上的 GVPConfiguration 对象为空。

关于java - 奇怪的NPE : primitive field null inside instance method,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/60190502/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com