我开始开发Android应用程序了!我正在开始我的第一个并遇到了一个早期问题。该应用程序的作用是有两个按钮,您可以单击它们来添加或减去主变量。一切顺利,直到我在Nexus 4上进行测试时,按下按钮时它会关闭。我看了simiar问题,仍然无法弄清楚我的问题。谢谢!
logcat的:
04-16 10:42:48.528: D/libEGL(17421): loaded /system/lib/egl/libEGL_adreno200.so
04-16 10:42:48.538: D/libEGL(17421): loaded /system/lib/egl/libGLESv1_CM_adreno200.so
04-16 10:42:48.538: D/libEGL(17421): loaded /system/lib/egl/libGLESv2_adreno200.so
04-16 10:42:48.538: I/Adreno200-EGL(17421): <eglInitialize:269>: EGL 1.4 QUALCOMM build: Nondeterministic AU_full_mako_PARTNER-ANDROID/JB-MR1-DEV_CL2961380_release_AU (CL2961380)
04-16 10:42:48.538: I/Adreno200-EGL(17421): Build Date: 12/10/12 Mon
04-16 10:42:48.538: I/Adreno200-EGL(17421): Local Branch:
04-16 10:42:48.538: I/Adreno200-EGL(17421): Remote Branch: m/partner-android/jb-mr1-dev
04-16 10:42:48.538: I/Adreno200-EGL(17421): Local Patches: NONE
04-16 10:42:48.538: I/Adreno200-EGL(17421): Reconstruct Branch: NOTHING
04-16 10:42:48.568: D/OpenGLRenderer(17421): Enabling debug mode 0
04-16 10:42:52.592: D/AndroidRuntime(17421): Shutting down VM
04-16 10:42:52.592: W/dalvikvm(17421): threadid=1: thread exiting with uncaught exception (group=0x40bef930)
04-16 10:42:52.592: E/AndroidRuntime(17421): FATAL EXCEPTION: main
04-16 10:42:52.592: E/AndroidRuntime(17421): java.lang.NullPointerException
04-16 10:42:52.592: E/AndroidRuntime(17421): at com.frostbytedev.addsub.StartingPoint$2.onClick(StartingPoint.java:37)
04-16 10:42:52.592: E/AndroidRuntime(17421): at android.view.View.performClick(View.java:4204)
04-16 10:42:52.592: E/AndroidRuntime(17421): at android.view.View$PerformClick.run(View.java:17355)
04-16 10:42:52.592: E/AndroidRuntime(17421): at android.os.Handler.handleCallback(Handler.java:725)
04-16 10:42:52.592: E/AndroidRuntime(17421): at android.os.Handler.dispatchMessage(Handler.java:92)
04-16 10:42:52.592: E/AndroidRuntime(17421): at android.os.Looper.loop(Looper.java:137)
04-16 10:42:52.592: E/AndroidRuntime(17421): at android.app.ActivityThread.main(ActivityThread.java:5041)
04-16 10:42:52.592: E/AndroidRuntime(17421): at java.lang.reflect.Method.invokeNative(Native Method)
04-16 10:42:52.592: E/AndroidRuntime(17421): at java.lang.reflect.Method.invoke(Method.java:511)
04-16 10:42:52.592: E/AndroidRuntime(17421): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:793)
04-16 10:42:52.592: E/AndroidRuntime(17421): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:560)
04-16 10:42:52.592: E/AndroidRuntime(17421): at dalvik.system.NativeStart.main(Native Method)
04-16 10:43:22.033: D/AndroidRuntime(17514): Shutting down VM
04-16 10:43:22.033: W/dalvikvm(17514): threadid=1: thread exiting with uncaught exception (group=0x40bef930)
04-16 10:43:22.033: E/AndroidRuntime(17514): FATAL EXCEPTION: main
04-16 10:43:22.033: E/AndroidRuntime(17514): java.lang.NullPointerException
04-16 10:43:22.033: E/AndroidRuntime(17514): at com.frostbytedev.addsub.StartingPoint$2.onClick(StartingPoint.java:37)
04-16 10:43:22.033: E/AndroidRuntime(17514): at android.view.View.performClick(View.java:4204)
04-16 10:43:22.033: E/AndroidRuntime(17514): at android.view.View$PerformClick.run(View.java:17355)
04-16 10:43:22.033: E/AndroidRuntime(17514): at android.os.Handler.handleCallback(Handler.java:725)
04-16 10:43:22.033: E/AndroidRuntime(17514): at android.os.Handler.dispatchMessage(Handler.java:92)
04-16 10:43:22.033: E/AndroidRuntime(17514): at android.os.Looper.loop(Looper.java:137)
04-16 10:43:22.033: E/AndroidRuntime(17514): at android.app.ActivityThread.main(ActivityThread.java:5041)
04-16 10:43:22.033: E/AndroidRuntime(17514): at java.lang.reflect.Method.invokeNative(Native Method)
04-16 10:43:22.033: E/AndroidRuntime(17514): at java.lang.reflect.Method.invoke(Method.java:511)
04-16 10:43:22.033: E/AndroidRuntime(17514): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:793)
04-16 10:43:22.033: E/AndroidRuntime(17514): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:560)
04-16 10:43:22.033: E/AndroidRuntime(17514): at dalvik.system.NativeStart.main(Native Method)
04-16 10:43:23.685: I/Process(17514): Sending signal. PID: 17514 SIG: 9
我还有我的活动和班级文件。
的活动:
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:orientation="vertical"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:gravity="top"
android:paddingBottom="@dimen/activity_vertical_margin"
android:paddingLeft="@dimen/activity_horizontal_margin"
android:paddingRight="@dimen/activity_horizontal_margin"
android:paddingTop="@dimen/activity_vertical_margin"
tools:context=".StartingPoint" >
<TextView
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:text="Your total is 0"
android:textSize="45dp"
android:gravity="center"
android:id="@+id/tvDisplay"
/>
<Button
android:layout_width="250dp"
android:layout_height="wrap_content"
android:gravity="center"
android:text="Add One"
android:textSize="20dp"
android:id="@+id/bAdd" />
<Button
android:layout_width="250dp"
android:layout_height="wrap_content"
android:gravity="center"
android:text="Subtract One"
android:textSize="20dp"
android:id="@+id/bSub" />
</LinearLayout>
最后,我的班级文件:
package com.frostbytedev.addsub;
import android.os.Bundle;
import android.app.Activity;
import android.view.Menu;
import android.view.View;
import android.widget.Button;
import android.widget.TextView;
public class StartingPoint extends Activity {
int counter;
Button add, sub;
TextView display;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_starting_point);
counter = 0;
add=(Button) findViewById(R.id.bAdd);
sub=(Button) findViewById(R.id.bSub);
add.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
counter++;
display.setText("Your total is "+counter);
}
});
sub.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
// TODO Auto-generated method stub
counter--;
display.setText("Your total is "+counter);
}
});
}
@Override
public boolean onCreateOptionsMenu(Menu menu) {
// Inflate the menu; this adds items to the action bar if it is present.
getMenuInflater().inflate(R.menu.starting_point, menu);
return true;
}
}
答案 0 :(得分:3)
您需要找到textview的ID。
android:id="@+id/tvDisplay"
display = TextView findViewById(R.id.tvDisplay);
您的代码中没有上述声明,这是NullPointerException的原因。
找到上面的id后,将文本设置为textview
display.setText("Your total is "+counter);
说明:
像字符串,drawable和像按钮textview这样的视图的每个资源都会在R.java文件中有一个条目,如下所示
public static final int tvDisplay=0x7f080000;// value may differ
值为int。所以R.id.textview将是整数值。您需要通过查找id初始化textview,然后在TextView中设置文本。
答案 1 :(得分:3)
关于错误的更广泛的解释,所以你不会在一段时间内打开这样的另一个问题。
阅读错误:
java.lang.NullPointerException
04-16 10:42:52.592: E/AndroidRuntime(17421): at com.frostbytedev.addsub.StartingPoint$2.onClick(StartingPoint.java:37)
基本上该行(37)有null
。
转到该行并查看:
display.setText("Your total is "+counter);
您在setText(String text)
上呼叫display
。所以问题出在那里。
如果您在没有实例化display
(即为空)之前查看,那么您将在任何情况下调用方法。正如其他人指出的那样,只需使用findViewById获取View,将其转换为TextView并将其保存在显示变量中:
display = (TextView) findViewById(R.id.textview);
了解如何调试,这是关键!
答案 2 :(得分:1)
您需要将视图(tvDisplay
)分配给display
。目前display
仅被声明但未分配,因此 null 。
答案 3 :(得分:1)
您尚未初始化显示TextView
这样做
diplay = (TextView) findVidewById(R.id.tvDisplay);
答案 4 :(得分:1)
添加
display =(TextView)findViewById(R.id.your id);