setText之后的空指针异常

时间:2011-11-22 08:47:57

标签: android

我在Android中设置了我的文字后遇到了问题。那个场景是这样的:

我从我的一个类中使用putExtra然后开始意图。在第二个类我声明了一个String变量,它将捕获额外的代码:

String playername = " ";
String emailaddress = " ";

protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.gamepage);

    playername = getIntent().getStringExtra("pname");
    Log.v(TAG, "Player name set to : " + playername);
    emailaddress = getIntent().getStringExtra("eadd");
    Log.v(TAG, "Email set to : " + emailaddress);
    TextView playerName = (TextView)findViewById(R.id.playerName);
        Log.v(TAG, "view fetched");

我使用Logs来跟踪数据的传递,它似乎工作正常但是在添加了playerName.setText(playername);

的部分之后

问题现在开始,错误日志显示:

 11-22 16:30:50.271: WARN/dalvikvm(4621): threadid=1: thread exiting with uncaught exception (group=0x4001d800)
11-22 16:30:50.397: ERROR/AndroidRuntime(4621): FATAL EXCEPTION: main
11-22 16:30:50.397: ERROR/AndroidRuntime(4621): java.lang.RuntimeException: Unable to start activity ComponentInfo{arc.android.memorygame/arc.android.memorygame.SetGameScreen}: java.lang.NullPointerException
11-22 16:30:50.397: ERROR/AndroidRuntime(4621):     at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2663)
11-22 16:30:50.397: ERROR/AndroidRuntime(4621):     at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2679)
11-22 16:30:50.397: ERROR/AndroidRuntime(4621):     at android.app.ActivityThread.access$2300(ActivityThread.java:125)
11-22 16:30:50.397: ERROR/AndroidRuntime(4621):     at android.app.ActivityThread$H.handleMessage(ActivityThread.java:2033)
11-22 16:30:50.397: ERROR/AndroidRuntime(4621):     at android.os.Handler.dispatchMessage(Handler.java:99)
11-22 16:30:50.397: ERROR/AndroidRuntime(4621):     at android.os.Looper.loop(Looper.java:123)
11-22 16:30:50.397: ERROR/AndroidRuntime(4621):     at android.app.ActivityThread.main(ActivityThread.java:4627)
11-22 16:30:50.397: ERROR/AndroidRuntime(4621):     at java.lang.reflect.Method.invokeNative(Native Method)
11-22 16:30:50.397: ERROR/AndroidRuntime(4621):     at java.lang.reflect.Method.invoke(Method.java:521)
11-22 16:30:50.397: ERROR/AndroidRuntime(4621):     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:868)
11-22 16:30:50.397: ERROR/AndroidRuntime(4621):     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:626)
11-22 16:30:50.397: ERROR/AndroidRuntime(4621):     at dalvik.system.NativeStart.main(Native Method)
11-22 16:30:50.397: ERROR/AndroidRuntime(4621): Caused by: java.lang.NullPointerException
11-22 16:30:50.397: ERROR/AndroidRuntime(4621):     at arc.android.memorygame.SetGameScreen.onCreate(SetGameScreen.java:29)
11-22 16:30:50.397: ERROR/AndroidRuntime(4621):     at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1047)
11-22 16:30:50.397: ERROR/AndroidRuntime(4621):     at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2627)
11-22 16:30:50.397: ERROR/AndroidRuntime(4621):     ... 11 more

我的代码有问题吗?为什么它会返回Null Pointer Exception?

3 个答案:

答案 0 :(得分:3)

此行后可能playernamenull

playername = getIntent().getStringExtra("pname");
如果没有找到字符串值,

getStringExtra将返回null。

尝试这样的事情:

playername = getIntent().getStringExtra("pname");
if (playername == null)
    playername = "some default value";

稍后编辑:

如果您完全确定此时playername不是null,则表示由于某种原因findViewById返回null(错误,您的错误) xml或其他)。

顺便说一句,如果你有日志并且可以检查变量是否为null,你为什么不这样做而不是问? NullPointerException并不难以追踪,尤其是当您只有少量变量时。

答案 1 :(得分:0)

如果SetGameScreen的第29行是playerName.setText(playername);,并且您确定getIntent().getStringExtra("pname");返回了String而不是null,我会认为您得到NullPointerException是因为在您的XML布局中找不到playerName

如果在布局中找不到具有匹配ID的项目,方法findViewById()将返回null。

您应该检查gamepage.xml是否真的有TextView属性android:id="@+id/playerName"。 (如果有,您可以尝试将playerName更改为其他内容,然后再试一次。)

注意:尝试在此处发布gamepage.xml,以便我们为您检查。

答案 2 :(得分:0)

检查TextView playerName是否为空?