0

我有一个收集 rawQuery 结果的数组。它工作得很好,但是当它只有一个结果时会抛出这个异常。

public String [][] getList() {
        SQLiteDatabase db = this.getWritableDatabase();
        String [][] data;
        Cursor c = db.rawQuery("SELECT nombre FROM productos GROUP BY " +
            "nombre ORDER BY nombre", null);
        if (c.moveToFirst()) {
            data = new String[c.getCount()][1];
            int i = 0; char last = 1;
            do {
                data[i][0]=c.getString(c.getColumnIndex("nombre"));
                if(data[i][0].charAt(0)!=last) {
                            char [] a = {data[i][0].charAt(0)};
                String b = new String(a); 
                            data[i][1]=b; 
                            last = a[0];} else {
                    data[i][1]=null;
                }
                i++;
            } while ( c.moveToNext());
            db.close();
            return data;
        }
        data=new String[1][1]; data[0][0]="-1";
        db.close();
        return data;
    } 

该方法向自定义列表适配器提供了构建带有分隔符的 listView 所需的信息(这就是我在第二列中使用字符的原因)。你能帮助我吗?

4

1 回答 1

2

您正在初始化data一个数组new String[c.getCount()][1]。这意味着最高有效的第二个下标是 0,而不是 1。您需要一个双元素数组:new String[c.getCount()][2]

于 2013-01-13T10:55:03.307 回答