5

我收到此错误:[NSMutableArray objectAtIndex:]: index 0 beyond bounds for empty array尽管我的数据库中有 75 个项目。为什么它向我显示此错误?我试图从我的数据库中获取项目,但它告诉我索引 0。

+(NSMutableArray *)GetAttitudeItems
{
    NSArray *arrDocPath = NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES);
    NSString *strDestPath = [NSString stringWithFormat:@"%@/ItemsAndCategory.sqlite",[arrDocPath objectAtIndex:0]];


//sqlite3 *sqlite;

NSMutableArray *arrItemsList;
if(sqlite3_open([strDestPath UTF8String],&database)==SQLITE_OK)
{

    const char *strQuery = "SELECT * FROM Items WHERE CategoryName='ATTITUDE' ORDER BY RANDOM()";
    NSLog(@"The value is %s",strQuery);
    sqlite3_stmt *stmt;
    //char *err;

    arrItemsList  = [[NSMutableArray alloc]init];

    if(sqlite3_prepare_v2(database, strQuery , -1,&stmt, NULL)==SQLITE_OK)
    {
        while (sqlite3_step(stmt)==SQLITE_ROW) 
        {

            NSString *StrCatename = [NSString stringWithUTF8String:(char*)sqlite3_column_text(stmt, 1)];
            NSString *StrItemName = [NSString stringWithUTF8String:(char*)sqlite3_column_text(stmt, 0)];

            Itemslist *itemlist = [[Itemslist alloc]init];
            itemlist.CategoryValue = StrCatename;
            itemlist.ItemValue =StrItemName;
            [arrItemsList addObject:itemlist];

        }

    }

    if (stmt!=nil)
    {
        sqlite3_finalize(stmt);
    }
}



sqlite3_close(database);

return arrItemsList;

}

4

1 回答 1

2

如果您确信您的数据库调用应该返回数据,我会确保您的至少一个 if () else () 语句实际上受到了打击。否则,鉴于您在上面对其进行了初始化,您的数组为空:

NSMutableArray *arrAlert = [[NSMutableArray alloc]init];

一个简单的检查自己的方法是在链else的底部添加一个语句if else,并在那里断言一些东西(即,至少打印一些东西,对于初学者。)

于 2012-07-02T07:00:41.450 回答