【问题标题】:android java onClick Could not execute method of the activityandroid java onClick 无法执行活动的方法
【发布时间】:2015-05-30 23:34:43
【问题描述】:

这是我第一次使用 recyclerview,我收到一些关于 android:onClick="addItem" 的错误,这是我尝试向我的 recyclerview 添加一行文本时得到的。我通常使用手机来测试我的应用程序。

java.lang.IllegalStateException: Could not execute method of the activity
            at android.view.View$1.onClick(View.java:4012)
            at android.view.View.performClick(View.java:4761)
            at android.view.View$PerformClick.run(View.java:19767)
            at android.os.Handler.handleCallback(Handler.java:739)
            at android.os.Handler.dispatchMessage(Handler.java:95)
            at android.os.Looper.loop(Looper.java:135)
            at android.app.ActivityThread.main(ActivityThread.java:5312)
            at java.lang.reflect.Method.invoke(Native Method)
            at java.lang.reflect.Method.invoke(Method.java:372)
            at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:901)
            at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:696)
     Caused by: java.lang.reflect.InvocationTargetException
            at java.lang.reflect.Method.invoke(Native Method)
            at java.lang.reflect.Method.invoke(Method.java:372)
            at android.view.View$1.onClick(View.java:4007)
            at android.view.View.performClick(View.java:4761)
            at android.view.View$PerformClick.run(View.java:19767)
            at android.os.Handler.handleCallback(Handler.java:739)
            at android.os.Handler.dispatchMessage(Handler.java:95)
            at android.os.Looper.loop(Looper.java:135)
            at android.app.ActivityThread.main(ActivityThread.java:5312)
            at java.lang.reflect.Method.invoke(Native Method)
            at java.lang.reflect.Method.invoke(Method.java:372)
            at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:901)
            at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:696)
     Caused by: java.lang.NullPointerException: Attempt to invoke virtual method 'android.text.Editable android.widget.EditText.getText()' on a null object reference
            at com.sapps.app.testapp2.MainActivity.addItem(MainActivity.java:53)
            at java.lang.reflect.Method.invoke(Native Method)
            at java.lang.reflect.Method.invoke(Method.java:372)
            at android.view.View$1.onClick(View.java:4007)
            at android.view.View.performClick(View.java:4761)
            at android.view.View$PerformClick.run(View.java:19767)
            at android.os.Handler.handleCallback(Handler.java:739)
            at android.os.Handler.dispatchMessage(Handler.java:95)
            at android.os.Looper.loop(Looper.java:135)
            at android.app.ActivityThread.main(ActivityThread.java:5312)
            at java.lang.reflect.Method.invoke(Native Method)
            at java.lang.reflect.Method.invoke(Method.java:372)
            at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:901)
            at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:696)

这是我认为是错误的代码,但我不确切知道:

 public class MainActivity extends ActionBarActivity {

private EditText mText;
private RecyclerView.LayoutManager mLayoutManager;
private RecyclerView recyclerView;
private Button btn;
private CustomRecyclerAdapter mAdapter;

private List<Data> mData = new ArrayList<>();

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

    // Initializing views.
    mText = (EditText) findViewById(R.id.textEt);
    recyclerView = (RecyclerView) findViewById(R.id.recycler);

    // If the size of views will not change as the data changes.
    recyclerView.setHasFixedSize(true);

    // Setting the LayoutManager.
    mLayoutManager = new LinearLayoutManager(this);
    recyclerView.setLayoutManager(mLayoutManager);

    // Setting the adapter.
    CustomRecyclerAdapter mAdapter = new CustomRecyclerAdapter();
    recyclerView.setAdapter(mAdapter);
}



// Called when add button is clicked.
public void addItem(View v) {

    if(mText!=null) {
        Data dataToAdd = new Data(mText.getText().toString()); mData.add(dataToAdd);
    }
}

}

这是我的 recyclerview 适配器,可以肯定地知道:

public class CustomRecyclerAdapter extends RecyclerView.Adapter<RecyclerViewHolder> {

    CustomRecyclerAdapter mAdapter;

    private List<Data> mData = Collections.emptyList();

    public CustomRecyclerAdapter() {
        // Pass context or other static stuff that will be needed.
    }

    public void updateList(List<Data> data) {
        mData = data;
        notifyDataSetChanged();
    }
    @Override
    public int getItemCount() {
        return mData.size();
    }

    @Override
    public RecyclerViewHolder onCreateViewHolder(ViewGroup viewGroup, int position) {
        LayoutInflater inflater = LayoutInflater.from(viewGroup.getContext());
        View itemView = inflater.inflate(R.layout.list_item, viewGroup, false);
        return new RecyclerViewHolder(itemView);
    }

    @Override
    public void onBindViewHolder(RecyclerViewHolder viewHolder, int position) {
        viewHolder.title.setText(mData.get(position).text);
    }

    public void addItemInRec(int position, Data data) {
        mData.add(data);
        notifyItemInserted(position);
    }

    public void removeItem(int position) {
        mData.remove(position);
        notifyItemRemoved(position);
    }
}

我的 MainActivity xml 文件:

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:orientation="vertical"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    tools:context=".MainActivity">

    <LinearLayout
        android:orientation="horizontal"
        android:layout_width="match_parent"
        android:layout_height="wrap_content">

        <EditText
            android:id="@+id/textEt"
            android:layout_width="0dp"
            android:layout_height="wrap_content"
            android:layout_weight="1"
            android:hint="Text"/>

        <Button
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:text="Add"
            android:onClick="addItem"/>

    </LinearLayout>

    <android.support.v7.widget.RecyclerView
        android:id="@+id/recycler"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:scrollbars="vertical"/>

</LinearLayout>

也许是我的 ViewHolder:

public class RecyclerViewHolder extends RecyclerView.ViewHolder {

    public TextView title;

    public RecyclerViewHolder(View itemView) {
        super(itemView);
        title = (TextView) itemView.findViewById(R.id.title);
    }
}

或者Data.java类:

public class Data {

        public String text;
        public Data(String text) {
            this.text = text;
        }
    }

【问题讨论】:

  • Caused by: java.lang.NullPointerException: Attempt to invoke virtual method 'android.text.Editable android.widget.EditText.getText()' on a null object reference 是否有任何错误信息令人困惑?
  • 我该怎么办?我不是调试专家;)
  • 这一行at com.sapps.app.testapp2.MainActivity.addItem(MainActivity.java:53) 告诉您确切异常在哪里...确保您的对象不为空。这很简单。这也意味着,在按下按钮并调用该代码之前,不会执行此行 EditText mText = (EditText) findViewById(R.id.textEt);。由于您没有在此之前包含这些内容,因此很难说。
  • do : if(mText!=null) { Data dataToAdd = new Data(mText.getText().toString()); mData.add(dataToAdd);当你在上面初始化它时,还要检查为什么 mText 为空?也许分享你的xml?
  • Ryan 可能是正确的,也许它还没有初始化,你正在点击添加按钮

标签: java android xml android-recyclerview


【解决方案1】:

将 public void addItemInRec 更改为 public void addItem。 mainActivity 中没有 onClick 的方法。

【讨论】:

    【解决方案2】:

    addItem(View v) 中的视图仅指按钮。 您想要的 EditText 对象不在按钮中,它在按钮的父视图中。 如果您尝试从按钮视图访问对象,它将为空,因为按钮没有它。 相反,您需要从按钮的父视图访问对象。

    // Solution:
    public void addItem(View v) {
        View parentView = (View) v.getParent();
        EditText mText = (EditText) parentView.findViewById(R.id.textEt);
        Log.d("LOG", mText.getText().toString()));
    }
    

    我知道从技术上讲,这并不能解决问题中的代码。但是问题中的代码已经从产生错误的地方改变了,所以这将解决实际产生问题的原始错误代码。 我猜原来的错误代码是这样的:

    // My guess this was the original buggy code
    // MainActivity.java
    public void addItem(View v) {
        EditText mText = (EditText) v.findViewById(R.id.textEt);
        Data dataToAdd = new Data(mText.getText().toString());
        mData.add(dataToAdd);
    }
    
    // MainActivity.xml
    <LinearLayout>
        <EditText
            android:id="@+id/textEt"
        />
    
        <Button
            android:text="Add"
            android:onClick="addItem"/>
    </LinearLayout>
    

    【讨论】:

      【解决方案3】:

      关键在你的错误信息中:

      Caused by: java.lang.NullPointerException: Attempt to invoke virtual method 'android.text.Editable android.widget.EditText.getText()' on a null object reference
                  at com.sapps.app.testapp2.MainActivity.addItem(MainActivity.java:53)
      

      从错误输出中学习的一个好技巧是查看每个“Caused by”语句,并扫描日志,直到找到引用的您自己的文件之一。然后,错误日志的那部分甚至会告诉您代码在哪一行失败(在这种情况下,它是 MainActivity.java 上的第 53 行)。

      Java 中的空指针异常是当您尝试在某个对象“A”上调用方法时,但该对象“A”当前为 null

      所以这个错误信息意味着: “在 MainActivity.java 的第 53 行,你试图在一些尚不存在的对象上调用方法,所以我崩溃了。”

      失败的方法是EditText mText = (EditText) findViewById(R.id.textEt);

      通常这种类型的失败意味着您没有从布局中找到正确的 ID。仔细检查 textEt 是否是此布局元素的正确 ID。

      编辑:

      仍然不确定为什么您的视图没有被填充,但我确实注意到您的适配器有错误。您正在重新定义 mAdapter,因此您有 2 个副本,一个在本地范围内,一个作为 MainActivity 的成员。这肯定会搞砸的。

      就在这里:

      // Setting the adapter.
      CustomRecyclerAdapter mAdapter = new CustomRecyclerAdapter();
      recyclerView.setAdapter(mAdapter)
      

      您正在本地重新定义mAdapter。改为这样做:

      // Setting the adapter.
      mAdapter = new CustomRecyclerAdapter();
      recyclerView.setAdapter(mAdapter)
      

      【讨论】:

      • 我的 MainActivity.xml 文件中已经有了 android:id="@+id/textEt"。但会不会是我的 LinearLayout 导致了错误?
      • 您可以在 MainActivity.java 的第 53 行放置一个断点。双击文件左侧的“装订线”,会出现一个小红点。然后不要点击播放按钮,而是点击错误按钮。当您的代码到达该行时,它将停止执行。然后你可以检查所有布局的值,看看什么是空的,什么不是。
      • 我得到了很多 = null;
      • android.widget.EditText{1d699d85 VFED..CL ......I. 0,0-0,0 #7f08003f app:id/textEt}
      • Android Studio 等任何 IDE 上的“gutter”是行号和代码文件之间的空间,您可以在其中添加断点 thatjeffsmith.wpengine.com/wp-content/uploads/2012/01/… 看起来您可以让调试器正常工作。如果您看到很多空值,听起来好像视图没有被填充或其他东西。您可以编辑您的问题以包含您的所有 MainActivity.java 吗?
      【解决方案4】:

      你在getText()调用上得到一个空指针

      意思是下面一行:

      EditText mText = (EditText) findViewById(R.id.textEt);
      

      返回null,解决方法是检查布局,让textEt在上面。

      编辑:

      如果您确定它在布局中,请删除 EditText 声明。

      在类范围内声明为private EditText mText;

      setContentView(R.layout.name_of_layout_here);
      mText = (EditText) findViewById(R.id.textEt);
      

      【讨论】:

      • textEt 已经在我的 mainactivity.xml 文件中:&lt;EditText android:id="@+id/textEt" android:layout_width="0dp" android:layout_height="wrap_content" android:layout_weight="1" android:hint="Text"/&gt;
      • @svenvdz 所以这意味着你有另一个公共变量冲突,因为EditText mText 在另一个范围内声明。您需要显示更多代码
      猜你喜欢
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      相关资源
      最近更新 更多