将Android Cursor转换为数组的ArrayList

时间:2011-09-12 13:26:45

标签: android arraylist cursor

我尝试将我的Cursor数据转换为arraylist。但最后,arraylist中的所有数据都被最后一行所覆盖。我做错了什么?

Cursor c = myDbHelper.getLvl1Cata();
        String[] data = new String[3];
        c.moveToFirst();
        while(!c.isAfterLast()) {
                data[0] = Integer.toString(c.getInt(0));
                data[1] = c.getString(1);
                data[2] = Integer.toString(c.getInt(2));
                Log.e("cc", data[1]);
                catalogueData.add(data);
                c.moveToNext();
        }   

3 个答案:

答案 0 :(得分:11)

试试这个

Cursor c = myDbHelper.getLvl1Cata();
String[] data;
if (c != null) {
    while(c.moveToNext()) {
        data = new String[3]; // Note this addition
        data[0] = Integer.toString(c.getInt(0));
        data[1] = c.getString(1);
        data[2] = Integer.toString(c.getInt(2));
        Log.e("cc", data[1]);
        catalogueData.add(data);
    }
    c.close();
}

data是一个字符串数组。在原始代码中,您多次将相同的数组添加到catalogueData结构中。您每次都更改了数组内容的值,但它仍然是相同的数组对象。所以你最终得到catalogueData持有对单个数组的多个引用,并且该数组只能有data[0]的一个值:你设置它的最后一件事。

这个答案通过为游标中的每一行使用一个新的不同数组来解决这个问题。

答案 1 :(得分:1)

试试这个:

if(mycursor!=null){    
            do{
    TextView name = (TextView)view.findViewById(R.id.contact_name);               
    name.setText(cursor.getString(cursor.getColumnIndex
                (Displayname)));
    mycursor.moveToNext();
            }while (mycursor.isLast());
        }

答案 2 :(得分:0)

String[] data = new String[3];放入while循环中。你每次迭代都会覆盖数组对象。