【问题标题】:Android app crashes when I implement onclicklistener当我实现 onclicklistener 时,Android 应用程序崩溃
【发布时间】:2014-06-07 10:42:16
【问题描述】:

我在尝试实现 onClickListener 时总是遇到错误。

这是我的代码

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

    Button btn_submit = (Button) findViewById(R.id.btn_submit);
    btn_submit.setOnClickListener(new OnClickListener() {

        @Override
        public void onClick(View v) {
            // TODO Auto-generated method stub

        }
    });     

这是我的 XML 代码: 日志猫

06-07 02:54:05.901: E/AndroidRuntime(19667): FATAL EXCEPTION: main
06-07 02:54:05.901: E/AndroidRuntime(19667): Process: com.gonzalo.ejemplo, PID: 19667
06-07 02:54:05.901: E/AndroidRuntime(19667): java.lang.RuntimeException: Unable to start activity ComponentInfo{com.gonzalo.ejemplo/com.gonzalo.ejemplo.MainActivity}: java.lang.NullPointerException
06-07 02:54:05.901: E/AndroidRuntime(19667):    at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2305)
06-07 02:54:05.901: E/AndroidRuntime(19667):    at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2363)
06-07 02:54:05.901: E/AndroidRuntime(19667):    at android.app.ActivityThread.access$900(ActivityThread.java:161)
06-07 02:54:05.901: E/AndroidRuntime(19667):    at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1265)
06-07 02:54:05.901: E/AndroidRuntime(19667):    at android.os.Handler.dispatchMessage(Handler.java:102)
06-07 02:54:05.901: E/AndroidRuntime(19667):    at android.os.Looper.loop(Looper.java:157)
06-07 02:54:05.901: E/AndroidRuntime(19667):    at android.app.ActivityThread.main(ActivityThread.java:5356)
06-07 02:54:05.901: E/AndroidRuntime(19667):    at java.lang.reflect.Method.invokeNative(Native Method)
06-07 02:54:05.901: E/AndroidRuntime(19667):    at java.lang.reflect.Method.invoke(Method.java:515)
06-07 02:54:05.901: E/AndroidRuntime(19667):    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1265)
06-07 02:54:05.901: E/AndroidRuntime(19667):    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1081)
06-07 02:54:05.901: E/AndroidRuntime(19667):    at dalvik.system.NativeStart.main(Native Method)
06-07 02:54:05.901: E/AndroidRuntime(19667): Caused by: java.lang.NullPointerException
06-07 02:54:05.901: E/AndroidRuntime(19667):    at com.gonzalo.ejemplo.MainActivity.onCreate(MainActivity.java:27)
06-07 02:54:05.901: E/AndroidRuntime(19667):    at android.app.Activity.performCreate(Activity.java:5426)
06-07 02:54:05.901: E/AndroidRuntime(19667):    at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1105)
06-07 02:54:05.901: E/AndroidRuntime(19667):    at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2269)
06-07 02:54:05.901: E/AndroidRuntime(19667):    ... 11 more
06-07 02:59:05.974: I/Process(19667): Sending signal. PID: 19667 SIG: 9

所以..知道如何解决它吗??

谢谢

【问题讨论】:

  • 我猜你正在使用最新的 ADT 并创建了一个新项目,其中包含 Fragment。在这种情况下,Button 将在您的片段 XML 文件中,而不是在活动文件中。您需要将Button 代码移动到您的Fragment

标签: android onclicklistener


【解决方案1】:

findViewById 可能返回 null。确保您的布局中有一个带有android:id="@+id/btn_submit" 的按钮。

【讨论】:

    【解决方案2】:

    这个变量可能是问题所在。

    Button btn_submit = (Button) findViewById(R.id.btn_submit);
    

    检查你的activity_main.xml,如果存在btn_submit,也许有另一个名字。

    【讨论】:

    • 谢谢,我把活动弄糊涂了,这就是给我返回空值的原因。
    猜你喜欢
    • 2012-10-14
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2021-11-03
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多