【问题标题】:Null Pointer Exception on Virtual Method on a null object reference [duplicate]空对象引用上的虚拟方法上的空指针异常[重复]
【发布时间】:2016-01-20 20:22:15
【问题描述】:

您好,我已经为此苦苦思索了一段时间。我了解 NullPtr 是什么以及编译器为什么抛出异常,我只是不知道为什么。以下是相关代码:

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

    final Button signBtn = (Button) findViewById(R.id.signInBtn);
    signBtn.setOnClickListener(new View.OnClickListener() {
        @Override
        public void onClick(View view) {
            Intent intent = new Intent(MainActivity.this, LoginActivity.class);
            startActivity(intent);
        }
    });

空指针是signBtn.setOnClickListener()

01-20 20:15:02.284 10219-10219/com.lukewaugh.app E/AndroidRuntime: FATAL EXCEPTION: main
01-20 20:15:02.284 10219-10219/com.lukewaugh.app E/AndroidRuntime: Process: com.lukewaugh.app, PID: 10219
01-20 20:15:02.284 10219-10219/com.lukewaugh.app E/AndroidRuntime: java.lang.RuntimeException: Unable to start activity ComponentInfo{com.lukewaugh.app/com.lukewaugh.app.MainActivity}: java.lang.NullPointerException: Attempt to invoke virtual method 'void android.widget.Button.setOnClickListener(android.view.View$OnClickListener)' on a null object reference
01-20 20:15:02.284 10219-10219/com.lukewaugh.app E/AndroidRuntime:     at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2354)
01-20 20:15:02.284 10219-10219/com.lukewaugh.app E/AndroidRuntime:     at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2416)
01-20 20:15:02.284 10219-10219/com.lukewaugh.app E/AndroidRuntime:     at android.app.ActivityThread.access$900(ActivityThread.java:154)
01-20 20:15:02.284 10219-10219/com.lukewaugh.app E/AndroidRuntime:     at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1322)
01-20 20:15:02.284 10219-10219/com.lukewaugh.app E/AndroidRuntime:     at android.os.Handler.dispatchMessage(Handler.java:102)
01-20 20:15:02.284 10219-10219/com.lukewaugh.app E/AndroidRuntime:     at android.os.Looper.loop(Looper.java:135)
01-20 20:15:02.284 10219-10219/com.lukewaugh.app E/AndroidRuntime:     at android.app.ActivityThread.main(ActivityThread.java:5300)
01-20 20:15:02.284 10219-10219/com.lukewaugh.app E/AndroidRuntime:     at java.lang.reflect.Method.invoke(Native Method)
01-20 20:15:02.284 10219-10219/com.lukewaugh.app E/AndroidRuntime:     at java.lang.reflect.Method.invoke(Method.java:372)
01-20 20:15:02.284 10219-10219/com.lukewaugh.app E/AndroidRuntime:     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:904)
01-20 20:15:02.284 10219-10219/com.lukewaugh.app E/AndroidRuntime:     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:699)
01-20 20:15:02.284 10219-10219/com.lukewaugh.app E/AndroidRuntime:  Caused by: java.lang.NullPointerException: Attempt to invoke virtual method 'void android.widget.Button.setOnClickListener(android.view.View$OnClickListener)' on a null object reference
01-20 20:15:02.284 10219-10219/com.lukewaugh.app E/AndroidRuntime:     at com.lukewaugh.app.MainActivity.onCreate(MainActivity.java:30)
01-20 20:15:02.284 10219-10219/com.lukewaugh.app E/AndroidRuntime:     at android.app.Activity.performCreate(Activity.java:6088)
01-20 20:15:02.284 10219-10219/com.lukewaugh.app E/AndroidRuntime:     at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1106)
01-20 20:15:02.284 10219-10219/com.lukewaugh.app E/AndroidRuntime:     at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2307)
01-20 20:15:02.284 10219-10219/com.lukewaugh.app E/AndroidRuntime:     at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2416) 
01-20 20:15:02.284 10219-10219/com.lukewaugh.app E/AndroidRuntime:     at android.app.ActivityThread.access$900(ActivityThread.java:154) 
01-20 20:15:02.284 10219-10219/com.lukewaugh.app E/AndroidRuntime:     at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1322) 
01-20 20:15:02.284 10219-10219/com.lukewaugh.app E/AndroidRuntime:     at android.os.Handler.dispatchMessage(Handler.java:102) 
01-20 20:15:02.284 10219-10219/com.lukewaugh.app E/AndroidRuntime:     at android.os.Looper.loop(Looper.java:135) 
01-20 20:15:02.284 10219-10219/com.lukewaugh.app E/AndroidRuntime:     at android.app.ActivityThread.main(ActivityThread.java:5300) 
01-20 20:15:02.284 10219-10219/com.lukewaugh.app E/AndroidRuntime:     at java.lang.reflect.Method.invoke(Native Method) 
01-20 20:15:02.284 10219-10219/com.lukewaugh.app E/AndroidRuntime:     at java.lang.reflect.Method.invoke(Method.java:372) 
01-20 20:15:02.284 10219-10219/com.lukewaugh.app E/AndroidRuntime:     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:904) 
01-20 20:15:02.284 10219-10219/com.lukewaugh.app E/AndroidRuntime:     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:699) 
01-20 20:15:02.286 10219-10219/com.lukewaugh.app D/AppTracker: App Event: crash
01-20 20:15:02.337 10219-10219/com.lukewaugh.app I/Process: Sending signal. PID: 10219 SIG: 9

【问题讨论】:

  • 显然activity_main布局中没有signInBtnfindViewById()返回null。
  • @laalto 感谢您的回复,signInBtn 在fragment_mainactivity_main 是导航抽屉。
  • 那么正确设置点击监听的地方就是fragment了。

标签: java android nullpointerexception virtual-functions


【解决方案1】:

(新的 View.OnClickListener() 方法在代码中产生空指针异常。尝试初始化 View 类对象。

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 2018-06-07
    • 1970-01-01
    • 1970-01-01
    • 2018-04-11
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多