android.database.CursorIndexOutOfBoundsException:索引-1请求

时间:2010-12-19 06:29:54

标签: android

我正在尝试使用RawContacts.entityIterator阅读所有联系人,但我看到了这个错误:

android.database.CursorIndexOutOfBoundsException:索引-1请求

以下是我的代码:

ContentResolver cr = getContentResolver();
        Cursor cur = cr.query(Contacts.CONTENT_URI, 
       null, null, null, null);

String id = cur.getString(cur.getColumnIndex(Contacts._ID));

if (cur.getCount() > 0) {
        while (cur.moveToNext()) {
         final Uri uri = RawContactsEntity.CONTENT_URI;
            final String selection = Data.CONTACT_ID + "=?";
            final String[] selectionArgs = new String[] {id};

            final Map<String, List<ContentValues>> contentValuesListMap =
                new HashMap<String, List<ContentValues>>();
            EntityIterator entityIterator = null;

            entityIterator = RawContacts.newEntityIterator(cr.query(
                    uri, null, selection, selectionArgs, null));

            while (entityIterator.hasNext()) {
                Entity entity = entityIterator.next();
                for (NamedContentValues namedContentValues : entity.getSubValues()) {
                    ContentValues contentValues = namedContentValues.values;
                    String key = contentValues.getAsString(Data.MIMETYPE);
                    if (key != null) {
                        List<ContentValues> contentValuesList =
                                contentValuesListMap.get(key);
                        if (contentValuesList == null) {
                            contentValuesList = new ArrayList<ContentValues>();
                            contentValuesListMap.put(key, contentValuesList);
                        }
                        contentValuesList.add(contentValues);
                    }
                }
            }
            Log.i(tag, "Contact index=" + id);
        } 
    }

有人可以告诉我我的代码有什么问题。

2 个答案:

答案 0 :(得分:26)

执行query后,您必须致电cur.moveToFirst() ...

试试这个

ContentResolver cr = getContentResolver();
        Cursor cur = cr.query(Contacts.CONTENT_URI, 
       null, null, null, null);

if(cur != null && cur.moveToFirst())
{
       String id = cur.getString(cur.getColumnIndex(Contacts._ID));

        if (cur.getCount() > 0) {
         ...

答案 1 :(得分:2)

不需要调用moveToFirst,但要确保在访问值之前移动到任何返回的行(请参阅moveToLast()moveToPosition(int position),...)。< / p>

所以这一个:

Cursor cur = cr.query(Contacts.CONTENT_URI, null, null, null, null);

while (cur.moveToNext()) {
    String id = cur.getString(cur.getColumnIndex(Contacts._ID));
    final Uri uri = RawContactsEntity.CONTENT_URI;

会起作用 - 甚至更好,因为如果你继续......

,那么接受的答案会出现问题
while (cur.moveToNext()) {

if (cur.getCount() > 0) { 

它会跳过第一行,这可能并不明显。