gpt4 book ai didi

java - 如何修复 "Attempt to invoke method on a null object reference"?

转载 作者:行者123 更新时间:2023-12-01 11:55:54 28 4
gpt4 key购买 nike

我这里有一个问题。我试图在检测到某种电视型号时显示 THX Logo 。但它给出了 01-01 00:00:46.255: E/AndroidRuntime(2566): java.lang.NullPointerException: 尝试调用虚拟方法 'boolean jp.co.sharp.av.android.tvmodellibrary.ProductInformation.isThxFeature ()' 在空对象引用上。我想我已经进行了 Null 检查,但我的代码仍然无法工作。下面是我的代码,它是 Spot.java 文件:

public static void showAVMode(Context context, String AVMode) {
mContext = context;
spotText = getAvModeText(AVMode);
spotType= "";
call_Spot=3000;
if (mContext != null) {
spotType = mContext.getString(R.string.AVM_name);
currentSpot = 5;
if (view_Spot != null) {
ImageView spotIcon = (ImageView) view_Spot.findViewById(R.id.spot_icon);
if (mProductInformation.isThxFeature()) {
TvLog.d(TAG, "Current Tv have THX feature");
spotIcon.setBackgroundResource(R.drawable.set_thx);
} else {
TvLog.d(TAG, "Current Tv doesn't have THX feature and EnergyStar");
spotIcon.setVisibility(View.GONE);
}
} else {
//ImageView spotIcon = (ImageView) view_Spot.findViewById(R.id.spot_icon);
//spotIcon.setVisibility(View.VISIBLE);
//spotIcon.setBackgroundResource(R.drawable.set_thx);
TvLog.d(TAG, "context is null");
}
show();
} else {
TvLog.d(TAG, "context is null");
}
}

下面是 logcat 错误:

01-01 00:00:46.255: E/AndroidRuntime(2566): FATAL EXCEPTION: main
01-01 00:00:46.255: E/AndroidRuntime(2566): Process: jp.co.sharp.av.android.tvcore, PID: 2566
01-01 00:00:46.255: E/AndroidRuntime(2566): java.lang.NullPointerException: Attempt to invoke virtual method 'boolean jp.co.sharp.av.android.tvmodellibrary.ProductInformation.isThxFeature()' on a null object reference
01-01 00:00:46.255: E/AndroidRuntime(2566): at jp.co.sharp.av.android.tvcore.ui.view.Spot.showAVMode(Spot.java:127)
01-01 00:00:46.255: E/AndroidRuntime(2566): at jp.co.sharp.av.android.tvcore.treat.base.ScreenBase$1.handleMessage(ScreenBase.java:377)
01-01 00:00:46.255: E/AndroidRuntime(2566): at android.os.Handler.dispatchMessage(Handler.java:102)
01-01 00:00:46.255: E/AndroidRuntime(2566): at android.os.Looper.loop(Looper.java:135)
01-01 00:00:46.255: E/AndroidRuntime(2566): at android.app.ActivityThread.main(ActivityThread.java:5257)
01-01 00:00:46.255: E/AndroidRuntime(2566): at java.lang.reflect.Method.invoke(Native Method)
01-01 00:00:46.255: E/AndroidRuntime(2566): at java.lang.reflect.Method.invoke(Method.java:372)
01-01 00:00:46.255: E/AndroidRuntime(2566): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:903)
01-01 00:00:46.255: E/AndroidRuntime(2566): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:698)

请大家帮忙解决这个问题。 Spot.java:127 是这样的代码:if (mProductInformation.isThxFeature())

最佳答案

您的代码不显示 mProductInformation 来自何处或填充位置。

在使用 mProductInformation 调用 isThxFeature() 方法之前,添加一些代码来检查它是否为 null。

关于java - 如何修复 "Attempt to invoke method on a null object reference"?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28446157/

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