Android setOnClickListener抛出NullPointerException

Android setOnClickListener抛出NullPointerException,android,nullpointerexception,Android,Nullpointerexception,我正在按按钮呼叫OnClick侦听器。我已经这样做了好几次,而且以前也成功过。但不知何故,这次它抛出了一个NullPointerException。我已经查看了多个帖子,但我仍然没有得到它 @Override public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.search); Button viewRequest

我正在按按钮呼叫OnClick侦听器。我已经这样做了好几次,而且以前也成功过。但不知何故,这次它抛出了一个
NullPointerException
。我已经查看了多个帖子,但我仍然没有得到它

@Override
public void onCreate(Bundle savedInstanceState) {
  super.onCreate(savedInstanceState);

  setContentView(R.layout.search);

  Button viewRequests = (Button) findViewById(R.id.view_requests);

    viewRequests.setOnClickListener(new View.OnClickListener() { // NPException occurred here

    @Override
    public void onClick(View v) {

        System.out.println("View request is clicked");

    }
});
 }
资源文件:

<RelativeLayout
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:paddingLeft="20dp"
    android:paddingRight="20dp"
    android:paddingTop="10dp"
    android:paddingBottom="10dp" >

    <Button
        android:id="@+id/view_requests"
        android:background="@drawable/my_button"
        android:layout_width="120dp"
        android:layout_height="wrap_content"
        android:layout_centerInParent="true"
        android:layout_alignParentTop="true"
        android:paddingTop="3dp"
        android:paddingBottom="3dp"
        android:textSize="10sp"

        android:text="View Work Requests" />

</RelativeLayout>

如果要传递的布局文件实际上是
R.layout.search
,请清理并重新生成项目。

检查项目中是否有多个
search.xml
副本。也许您有单独的纵向/横向版本,或者特定于不同屏幕大小的版本。如果您这样做,所有版本都必须在按钮上设置
android:id=“@+id/view\u requests”
属性。

检查您在.xml fime和.java文件中的按钮是否具有相同的id。

是否可以发布准确的错误消息?如果删除了click listener,屏幕上是否显示了该按钮?还需要澄清的是,您发布的名为
search.xml
的布局xml文件位于您的
/res/layout/
文件夹中?奇怪。有可疑的日志吗?尝试清理并重新构建。检查布局文件是否正确?@Tim好的,按钮在布局中。它总是显示在屏幕上,我只有一份。谢谢你的提醒,我也有同样的问题。但是当我从AndroidManifest.xml中删除肖像时,问题就解决了。哦,你说得对。按钮位于充气布局文件中。如何设置ClickListener?我已经扩展了一个新的布局
quick\u search
,其中的按钮位于
search
。如何在
quick\u search
中设置ClickListener到元素?您实际上做得很好。只能在已充气的布局中充气视图。这就是为什么我告诉您,如果您的布局实际上包含具有该id的按钮,那么它可能与“损坏的”R.java文件有关。只是一个干净的构建项目,这应该解决它。否则,试试Tim在对你的问题的直接评论中告诉你的
07-20 17:26:40.411: D/AndroidRuntime(334): Shutting down VM
07-20 17:26:40.411: W/dalvikvm(334): threadid=1: thread exiting with uncaught exception  (group=0x40015560)
07-20 17:26:40.431: E/AndroidRuntime(334): FATAL EXCEPTION: main
07-20 17:26:40.431: E/AndroidRuntime(334): java.lang.RuntimeException: Unable to start activity ComponentInfo{com.rxprojects/com.rxprojects.activities.SearchActivity}: java.lang.NullPointerException
07-20 17:26:40.431: E/AndroidRuntime(334):  at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1647)
07-20 17:26:40.431: E/AndroidRuntime(334):  at android.app.ActivityThread.startActivityNow(ActivityThread.java:1487)
07-20 17:26:40.431: E/AndroidRuntime(334):  at android.app.LocalActivityManager.moveToState(LocalActivityManager.java:127)
07-20 17:26:40.431: E/AndroidRuntime(334):  at android.app.LocalActivityManager.startActivity(LocalActivityManager.java:339)
07-20 17:26:40.431: E/AndroidRuntime(334):  at android.widget.TabHost$IntentContentStrategy.getContentView(TabHost.java:654)
07-20 17:26:40.431: E/AndroidRuntime(334):  at android.widget.TabHost.setCurrentTab(TabHost.java:326)
07-20 17:26:40.431: E/AndroidRuntime(334):  at android.widget.TabHost$2.onTabSelectionChanged(TabHost.java:132)
07-20 17:26:40.431: E/AndroidRuntime(334):  at android.widget.TabWidget$TabClickListener.onClick(TabWidget.java:456)
07-20 17:26:40.431: E/AndroidRuntime(334):  at   android.view.View.performClick(View.java:2485)
07-20 17:26:40.431: E/AndroidRuntime(334):  at   android.view.View$PerformClick.run(View.java:9080)
07-20 17:26:40.431: E/AndroidRuntime(334):  at android.os.Handler.handleCallback(Handler.java:587)
07-20 17:26:40.431: E/AndroidRuntime(334):  at  android.os.Handler.dispatchMessage(Handler.java:92)
07-20 17:26:40.431: E/AndroidRuntime(334):  at android.os.Looper.loop(Looper.java:123)
07-20 17:26:40.431: E/AndroidRuntime(334):  at android.app.ActivityThread.main(ActivityThread.java:3683)
07-20 17:26:40.431: E/AndroidRuntime(334):  at java.lang.reflect.Method.invokeNative(Native Method)
07-20 17:26:40.431: E/AndroidRuntime(334):  at java.lang.reflect.Method.invoke(Method.java:507)
07-20 17:26:40.431: E/AndroidRuntime(334):  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:839)
07-20 17:26:40.431: E/AndroidRuntime(334):  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:597)
07-20 17:26:40.431: E/AndroidRuntime(334):  at dalvik.system.NativeStart.main(Native Method)
07-20 17:26:40.431: E/AndroidRuntime(334): Caused by: java.lang.NullPointerException
07-20 17:26:40.431: E/AndroidRuntime(334):  at   com.rxprojects.activities.SearchActivity.onCreate(SearchActivity.java:226)
07-20 17:26:40.431: E/AndroidRuntime(334):  at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1047)
07-20 17:26:40.431: E/AndroidRuntime(334):  at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1611)
07-20 17:26:40.431: E/AndroidRuntime(334):  ... 18 more