1

在我的应用程序中,我似乎无法调用我的应用程序中的任何布局对象。如果我访问包含使用 XML 文件的代码的任何类,应用程序将崩溃。像这样的线条

mButton = (Button)findViewById(R.id.get);
cweight   = (EditText)findViewById(R.id.cweight);
nweight   = (EditText)findViewById(R.id.nweight);
t = (TextView)findViewById(R.id.out);

这些代码行以前工作过,并且它们被称为布局文件存在。

用于此的 logcat 在下面,看着它我看不出问题出在哪里。特别是因为这段代码几天前就可以工作了。

05-23 16:12:43.790: E/AndroidRuntime(313): FATAL EXCEPTION: main
05-23 16:12:43.790: E/AndroidRuntime(313): java.lang.RuntimeException: Unable to start activity ComponentInfo{com.b00348312.workout/com.b00348312.workout.WorkoutChoice}: java.lang.NullPointerException
05-23 16:12:43.790: E/AndroidRuntime(313):  at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2663)
05-23 16:12:43.790: E/AndroidRuntime(313):  at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2679)
05-23 16:12:43.790: E/AndroidRuntime(313):  at android.app.ActivityThread.access$2300(ActivityThread.java:125)
05-23 16:12:43.790: E/AndroidRuntime(313):  at android.app.ActivityThread$H.handleMessage(ActivityThread.java:2033)
05-23 16:12:43.790: E/AndroidRuntime(313):  at android.os.Handler.dispatchMessage(Handler.java:99)
05-23 16:12:43.790: E/AndroidRuntime(313):  at android.os.Looper.loop(Looper.java:123)
05-23 16:12:43.790: E/AndroidRuntime(313):  at android.app.ActivityThread.main(ActivityThread.java:4627)
05-23 16:12:43.790: E/AndroidRuntime(313):  at java.lang.reflect.Method.invokeNative(Native Method)
05-23 16:12:43.790: E/AndroidRuntime(313):  at java.lang.reflect.Method.invoke(Method.java:521)
05-23 16:12:43.790: E/AndroidRuntime(313):  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:868)
05-23 16:12:43.790: E/AndroidRuntime(313):  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:626)
05-23 16:12:43.790: E/AndroidRuntime(313):  at dalvik.system.NativeStart.main(Native Method)
05-23 16:12:43.790: E/AndroidRuntime(313): Caused by: java.lang.NullPointerException
05-23 16:12:43.790: E/AndroidRuntime(313):  at com.b00348312.workout.WorkoutChoice.onCreate(WorkoutChoice.java:67)
05-23 16:12:43.790: E/AndroidRuntime(313):  at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1047)
05-23 16:12:43.790: E/AndroidRuntime(313):  at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2627)
05-23 16:12:43.790: E/AndroidRuntime(313):  ... 11 more

好的,鉴于共识似乎是它在第 67 行的空指针异常,但这是我在上面给出的第一行。给出的另一个解决方案是使用我在 onCreate 方法开始时所做的 setContent(view view)。

当上面给出的行不存在并且它们以前工作过时,该类工作得非常好,所以我不确定问题出在哪里。

4

2 回答 2

1

根据您Activity使用的内容,有几件事可能是错误的。setContentView(View view)如果您只是设置视图,您完成了吗?否则,如果您正在膨胀视图,则需要调用view.findViewById(id). 这样它就会在你刚刚膨胀的视图上调用它,否则它不会找到它。

编辑:一个简短的说明,我相信你需要setContentView(View view)在寻找视图setContentView(View view)之前打电话,所以findViewById(id)如果你这样做的话,需要在打电话之前打电话。

于 2012-05-23T16:26:42.547 回答
0

似乎问题出在WorkoutChoice第 67 行。您正在使用一个值为 null 的对象:

05-23 16:12:43.790: E/AndroidRuntime(313): Caused by: java.lang.NullPointerException
05-23 16:12:43.790: E/AndroidRuntime(313):  at com.b00348312.workout.WorkoutChoice.onCreate(WorkoutChoice.java:67)
于 2012-05-23T16:28:20.327 回答