notifyDataSetChanged() 不工作或触发?

notifyDataSetChanged() not working or triggered?

我正在尝试做的事情:

按下添加按钮时将值从 EditText 插入数据库。

用数据库中的数据填充列表视图。

问题:

当我单击添加按钮时,它会将值插入到数据库中,但不会将其填充到列表视图中。 当重新打开我的应用程序时,列表视图会刷新并显示来自数据库的数据。

这是我的代码:

public class MainActivity extends AppCompatActivity {

EditText editText;
Button add;
ListView listView;
final DBFunctions db=new DBFunctions(MainActivity.this);
ArrayAdapter<String> adapter;
String[] values;

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

    //xml inflation
    editText= (EditText) findViewById(R.id.editText);
    add= (Button) findViewById(R.id.button);
    listView= (ListView) findViewById(R.id.listView);
    values=db.getAlldata();
    adapter=new ArrayAdapter<String>(MainActivity.this,android.R.layout.simple_list_item_1,values);
    listView.setAdapter(adapter);
    add.setOnClickListener(new View.OnClickListener() {
        @Override
        public void onClick(View v)
        {
            String name = editText.getText().toString();
            if (!name.equals(""))
            {
                editText.setText("");
                long check = db.insertData(name);
                if (check < 0)
                {
                    Toast.makeText(MainActivity.this, "Error in insert query", Toast.LENGTH_SHORT).show();
                } else
                {
                    adapter.notifyDataSetChanged();
                    Toast.makeText(MainActivity.this, name + " inserted", Toast.LENGTH_SHORT).show();
                }
            }
            else
            {
                editText.setError("this field is empty");
            }

        }

    });
}

我是否在正确的地方使用了 adapter.notifyDataSetChanged

任何人都可以给我解决方案吗? 这对我有很大帮助。

提前致谢。

我认为您还应该将新元素插入到 values 中。 调用 notifyDataSetChanged() 时,实际数据集根本没有改变。 将元素添加到值中,然后调用 notifyDataSetChanged()。 您的适配器不适用于数据库,仅适用于 Array/LinkedList/ArrayList/Vector 调用的值。

我觉得其他一切都很好。

您的适配器正在使用从 values 数组中获取的数据填充 listView。您正在数据库中插入新数据,但这不会更改值数组,因此适配器没有发现任何要更改的内容。

也尝试更改值数组。为此,使用 ArrayList 而不是 Arrays 是更好的选择。

public class MainActivity extends AppCompatActivity {

EditText editText; 
Button add; 
ListView listView; 
final DBFunctions db=new DBFunctions(MainActivity.this);
ArrayAdapter<String> adapter; 
ArrayList<String> values;

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

    //xml inflation
    editText= (EditText) findViewById(R.id.editText);
    add= (Button) findViewById(R.id.button);
    listView= (ListView) findViewById(R.id.listView);
    values = new ArrayList<String>(Arrays.asList(db.getAlldata()));
    adapter=new ArrayAdapter<String>(MainActivity.this,android.R.layout.simple_list_item_1,values);
    listView.setAdapter(adapter);
    add.setOnClickListener(new View.OnClickListener() {
        @Override
        public void onClick(View v)
        {
            String name = editText.getText().toString();
            if (!name.equals(""))
            {
                editText.setText("");
                long check = db.insertData(name);
                if (check < 0)
                {
                    Toast.makeText(MainActivity.this, "Error in insert query", Toast.LENGTH_SHORT).show();
                } else
                {
                    values.add(name);
                    adapter.notifyDataSetChanged();
                    Toast.makeText(MainActivity.this, name + " inserted", Toast.LENGTH_SHORT).show();
                }
            }
            else
            {
                editText.setError("this field is empty");
            }

        }

    });


}