@implementation Level
@synthesize doors, rooms;
- (id) init
{
self = [super init];
if (self != nil) {
rooms = [[NSMutableArray alloc] init];
doors = [[NSMutableArray alloc] init];
}
return self;
}
- (void)generate{
int room_count = 2;
Room *room;
for (int i=0; i<room_count; i++) {
room = [[Room alloc] init];
[room generate_Doors];
[self.rooms addObject:room];
[room release];
}
for (int i=0; i<[rooms count]; i++) {
Room *r=[rooms objectAtIndex:i];
//After this point rooms is invalid
int l=[[r doors] count];
for (int j=0; j<l; j++) {
Door *d=[[[rooms objectAtIndex:i] doors] objectAtIndex:j];
[self.doors addObject:d];
}
}
}NSMutable массив недействительным после objectAtIndex
Это то, что я видел в отладчике
alt text http://img163.imageshack.us/img163/8090/20091117174111.png
Я думаю, что вы неверно истолковываете результаты, получаемые от отладчика. Проведите некоторую отладку NSLog, чтобы убедиться. например добавьте следующую строку под своим комментарием: NSLog (@ "у нас все еще есть что-то в нашем списке - позволяет увидеть количество объектов% d", [количество комнат]); – Till
В этом случае попробуйте 'NSLog (@" Первый объект:% @ ", [rooms objectAtIndex: 0]);'. –