我试图在用户单击注销按钮时启动新活动 . 但是,每当我单击按钮时,应用程序崩溃并在空对象引用上提供调用setOnClickListener . Java代码如下

package hanyang.hyu_se;

import android.content.Intent;
import android.os.Bundle;
import android.support.design.widget.FloatingActionButton;
import android.support.design.widget.Snackbar;
import android.support.v7.app.AppCompatActivity;
import android.support.v7.widget.ButtonBarLayout;
import android.support.v7.widget.Toolbar;
import android.view.View;
import android.view.Menu;
import android.view.MenuItem;
import android.widget.Button;
import android.widget.EditText;

public class MainActivity extends AppCompatActivity implements View.OnClickListener{

Button bNewGroup, bLogout;
EditText etSearch;

@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);
    Toolbar toolbar = (Toolbar) findViewById(R.id.toolbar);
    setSupportActionBar(toolbar);

    bNewGroup = (Button) findViewById(R.id.bNewGroup);
    bLogout = (Button) findViewById(R.id.bLogout);
    etSearch = (EditText) findViewById(R.id.etSearch);

    bLogout.setOnClickListener(this);
    bNewGroup.setOnClickListener(this);
}

@Override
public void onClick(View v) {
    switch(v.getId()) {
        case R.id.bLogout:
            startActivity(new Intent(this, login.class));

            break;
        case R.id.bNewGroup:

            break;
    }
}

@Override
public boolean onCreateOptionsMenu(Menu menu) {
    // Inflate the menu; this adds items to the action bar if it is present.
    getMenuInflater().inflate(R.menu.menu_main, menu);
    return true;
}

@Override
public boolean onOptionsItemSelected(MenuItem item) {
    // Handle action bar item clicks here. The action bar will
    // automatically handle clicks on the Home/Up button, so long
    // as you specify a parent activity in AndroidManifest.xml.
    int id = item.getItemId();

    //noinspection SimplifiableIfStatement
    if (id == R.id.action_settings) {
        return true;
    }

    return super.onOptionsItemSelected(item);
}
}

起初我的问题是当我手动键入Button时它没有调用widget按钮但是在解决了这个问题之后我现在停留在这个null对象引用上 .

我检查了我的XML,重要的是......

<Button
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:text="Logout"
    android:id="@+id/bLogout"
    android:layout_above="@+id/relativeLayout"
    android:layout_alignParentRight="true"
    android:layout_alignParentEnd="true" />

是否发生此错误是因为主要活动无法找到“bLogout”ID?我已多次检查语法,但我认为这不是导致问题的原因 .

EDIT :这是错误输出 . 抱歉格式化...我试着将它放在代码部分,但它不会让我因为某些原因在文本的前面添加空格...

---------崩溃的开始06-03 14:44:55.744 2400-2400 / hanyang.hyu_se E / AndroidRuntime:FATAL EXCEPTION:main进程:hanyang.hyu_se,PID:2400 java.lang.RuntimeException :无法启动活动ComponentInfo {hanyang.hyu_se / hanyang.hyu_se.login}:java.lang.NullPointerException:尝试在一个上调用虚拟方法'void android.widget.Button.setOnClickListener(android.view.View $ OnClickListener)' android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2387)的android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2325)中的null对象引用,位于android.app.ActivityThread.access $ 800(ActivityThread.java:151)at android.app.ActivityThread $ H.handleMessage(ActivityThread.java:1303)在android.app.Handler.dispatchMessage(Handler.java:102)android.app.Looper.loop(Looper.java:135)android.app .ActivityThread.main(ActivityThread.java:5254)位于com.android的java.lang.reflect.Method.invoke(Method.java:372)的java.lang.reflect.Method.invoke(Native Method)中 . internal.os.ZygoteInit $ MethodAndArgsCaller.run(ZygoteInit.java:903)在com.android.internal.os.ZygoteInit.main(ZygoteInit.java:698)产生的原因:显示java.lang.NullPointerException:尝试调用虚拟方法在android.app.Activity.performCreate(Activity.java)上hanyang.hyu_se.login.onCreate(login.java:31)的空对象引用上的void android.widget.Button.setOnClickListener(android.view.View $ OnClickListener)' :5990)android.app.Anstrumentation.callActivityOnCreate(Instrumentation.java:1106)android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2278)android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2387)at android .app.ActivityThread.access $ 800(ActivityThread.java:151)在Android.os.Handler.dispatchMessage(Handler.java:102)的android.app.ActivityThread $ H.handleMessage(ActivityThread.java:1303) .Looper.loop(Looper.java:135)在android.app.ActivityThread.main(ActivityThread.java:5254)的java.lang.reflect.Method.invoke(Native Me)在com.android.internal.os.ZygoteInit的com.android.internal.os.ZygoteInit $ MethodAndArgsCaller.run(ZygoteInit.java:903)的java.lang.reflect.Method.invoke(Method.java:372)上 . . 主要(ZygoteInit.java:698)