我正在尝试推送最终视图,其中将显示有关项目的所有信息。
- (void)tableView:(UITableView *)atableView didSelectRowAtIndexPath:(NSIndexPath *)indexPath
{
Item *itemObj; //object that holds data for cell for current view
ItemShow *itemOverViewObj; //data object for the next view
if(atableView==self.tableView)
{
//ordinary tabeView
itemObj=[self.itemsArray objectAtIndex:[indexPath row]];
}
else
{
//filtered with search tableView
itemObj=[self.filteredItems objectAtIndex:[indexPath row]];
}
//The array which will store the data for overview
NSMutableArray *itemsOverViewArr=[[NSMutableArray alloc]initWithCapacity:1];
DBAccess *access=[[DBAccess alloc]init];
//method for fetching data from db and inserting into array
itemsOverViewArr=[access getItemsOverView:itemObj.itemID];
[access closeDataBase];
[access release];
//here is the evil.
itemOverViewObj=[itemsOverViewArr objectAtIndex:[indexPath row]];
[itemsOverViewArr release];
ItemOverView *iov=[[ItemOverView alloc]initWithNibName:@"ItemOverView" bundle:nil];
iov.title=self.nominal;
[iov setItemShow:itemOverViewObj];
[self.navigationController pushViewController:iov animated:YES];
[iov release];
}
我之前检查过:
方法中选择getItemsOverView适用于100%。 itemObj.itemID获取正确的int。
问题起源于 itemOverViewObj = [itemsOverViewArr objectAtIndex:[indexPath row]];
错误: *由于未捕获的异常'NSRangeException'而终止应用程序,原因:'* - [NSMutableArray objectAtIndex:]:索引1超出边界[0 .. 0]'
DBAccess类中的getItemsOverview方法
-(NSMutableArray*)getItemsOverView:(int)itemID
{
NSMutableArray *itemsArray=[[[NSMutableArray alloc]init]autorelease];
const char *sqlItems=sqlite3_mprintf("SELECT itm.itemID,itm.itemYear,itm.rarity,dateComment,itm.mintage,dc.dateCode as dateCode,iaval.availability as avalibility,iaval.quality as quality,itm.Mintmark,itm.specialRemark\
from items itm\
join itemAvailability iaval on iaval.itemID=itm.itemID\
join dateCultures dc ON dc.dateCultureID=itm.dateCulture\
WHERE itm.itemID=%i",itemID);
sqlite3_stmt *statement;
int sqlResult = sqlite3_prepare_v2(database, sqlItems, -1, &statement, NULL);
if ( sqlResult== SQLITE_OK)
{
while (sqlite3_step(statement) == SQLITE_ROW)
{
ItemShow *itemShow=[[ItemShow alloc]init];
itemShow.itemID=sqlite3_column_int(statement, 0);
char *itemYear=(char *)sqlite3_column_text(statement, 1);
char *mintMark=(char *)sqlite3_column_text(statement, 2);
char *masterMark=(char *)sqlite3_column_text(statement, 3);
itemShow.rarity=sqlite3_column_int(statement, 4);
itemShow.availability=sqlite3_column_int(statement, 5);
itemShow.quality=sqlite3_column_int(statement, 6);
char *mintage=(char *)sqlite3_column_text(statement, 7);
itemShow.itemYear=(itemYear)?[NSString stringWithUTF8String:itemYear]:@"";
itemShow.mintMark=(mintMark)?[NSString stringWithUTF8String:mintMark]:@"";
itemShow.masterMark=(masterMark)?[NSString stringWithUTF8String:masterMark]:@"";
itemShow.mintage=(mintage)?[NSString stringWithUTF8String:mintage]:@"Unknown";
[itemsArray addObject:itemShow];
[itemShow release];
}
sqlite3_finalize(statement);
}
else
{
[self dbConnectionError];
}
return itemsArray;
}
提前谢谢
答案 0 :(得分:2)
异常消息说明了一切:您正在尝试访问itemsOverViewArr
中的第二个项目(索引1),但此数组只包含一个项目(索引0)。
为什么只有这样才能告诉您,因为您没有向我们展示相关代码。但肯定看起来像[access getItemsOverView:itemObj.itemID]
返回一个包含1个元素的数组。
此外,代码中至少有一个内存泄漏。 NSMutableArray *itemsOverViewArr=[[NSMutableArray alloc]initWithCapacity:1];
创建的数组在行itemsOverViewArr=[access getItemsOverView:itemObj.itemID];
后不再可访问,因此无法释放。您稍后发布itemsOverViewArr
的事实可能也是内存管理错误(在这种情况下是过度发布),因为getItemsOverView:
应该返回一个自动释放的对象。 (顺便说一句,你不应该命名这样的方法get...
,因为这个命名约定在Cocoa中暗示该方法通过指向方法参数之一的指针返回其结果。)
答案 1 :(得分:0)
做什么:
itemsOverViewArr=[access getItemsOverView:itemObj.itemID];
办?
如果它返回一个数组,则声明你的NSMutableArray如下:
NSMutableArray * itemsOverViewArr = [[NSMutableArray alloc] initWithArray: [access getItemsOverView:itemObj.itemID]];
然后还要确保在引用它时确保该可变数组中至少有一个项目。
换句话说:
if(itemsOverViewArr && ([itemsOverViewArr count] > 1))
{
itemOverViewObj=[itemsOverViewArr objectAtIndex:[indexPath row]];
...
...
答案 2 :(得分:0)
看起来您使用了多个tableView的委托
if(atableView==self.tableView)
确保您在此处访问正确的tableview:
itemOverViewObj=[itemsOverViewArr objectAtIndex:[indexPath row]];
或者你将得到错误的索引到数组中,这可能只有一个索引为0的项目,这将使索引1超出边界。