NSArray выдает ошибку NSZombie

#iphone #ios #uitableview #nsarray #nspredicate

#iPhone #iOS #uitableview uitableview #nsarray #nпредикат

Вопрос:

Я пытаюсь передать один объект массива (то есть nsdictionary из нескольких значений) обратно в мой основной вид.

в основном, когда я настраиваю представление, я анализирую некоторый xml в массив словарей. Затем я настраиваю свой tableview с одним из значений внутри NSDictionary, это значение также используется для настройки алфавитного скроллера и заголовков разделов. (это делается в методе, который я создал)

В конце этого метода я вызываю [self.TableView reloadData]; все загружается идеально, и все отображается нормально.

Теперь то, что я пытаюсь сделать, это настроить его так, чтобы при выборе ячейки я проверял значение внутри cell.textlabel и использовал его в качестве предиката для проверки моего массива словарей, как только он найдет соответствующую запись. Я хочу передать этот словарь в главное представление с помощью делегат, которого я сделал.

однако я получаю сообщение об ошибке, которое, как мне кажется, может произойти из-за моей перезагрузки .. но я не уверен. Вот как выглядит мой предикат.

 NSPredicate *pred = [NSPredicate predicateWithFormat:@"%K like %@",@"MANUFACTURER",cell.textLabel.text];
            NSArray *filter = [myDataArray filteredArrayUsingPredicate:pred]; //error happens here
            //check to see if the value is the correct one
            NSLog(@"My Filtered array = %@", filter);
            //once problem has been found set up the delegate here.
 

и это сообщение об ошибке, которое я получаю.

 2011-10-31 10:43:57.333 code[5812:207] *** -[__NSArrayM filteredArrayUsingPredicate:]: message sent to deallocated instance 0x6874210
 

myDataArray создается в делегатах NSXMLParser, как указано ниже.

//.ч

 NSMutableArray *myDataArray;
}
@property (nonatomic, retain) NSMutableArray *myDataArray;
 

//.м

 #pragma mark - Parsing lifecycle

- (void)startTheParsingProcess:(NSData *)parserData
{

    //myDataArray = [NSMutableArray arrayWithCapacity:8]; // not even sure if this is needed as its declared later on.

    NSXMLParser *parser = [[NSXMLParser alloc] initWithData:parserData]; //parserData passed to NSXMLParser delegate which starts the parsing process 

    [parser setDelegate:self];
    [parser parse]; // starts the event-driven parsing operation.
    [parser release];
}

- (void)parser:(NSXMLParser *)parser didStartElement:(NSString *)elementName namespaceURI:(NSString *)namespaceURI qualifiedName:(NSString *)qName attributes:(NSDictionary *)attributeDict
{
    if([elementName isEqualToString:@"Row"])
    {
        manufactureMutableDictionary = [[NSMutableDictionary alloc] initWithDictionary:attributeDict];
    }
    if([elementName isEqualToString:@"Rows"])
    {
        myDataArray = [NSMutableArray arrayWithCapacity:8];
    }
} 

- (void)parser:(NSXMLParser *)parser didEndElement:(NSString *)elementName namespaceURI:(NSString *)namespaceURI qualifiedName:(NSString *)qName
{
    if([elementName isEqualToString:@"Row"])
    {
        [myDataArray addObject:manufactureMutableDictionary];
    }
    [manufactureMutableDictionary release];
    manufactureMutableDictionary = nil;
}
 

Любая помощь была бы очень признательна, также, как вы думаете, я собираюсь правильно передать все значения словаря?

Комментарии:

1. Можете ли вы показать нам myDataArray , откуда это происходит?

2. Находится ли код, который вы только что добавили выше, в том же классе, NSPredicate что и код?

3. да. но, очевидно, разные методы.. итак, поскольку я объявил массив в файле .h, он должен быть доступен для всех локальных методов, да?

Ответ №1:

Вы используете autorelease общий массив

 myDataArray = [NSMutableArray arrayWithCapacity:8];
 

У вас настроены свойства, поэтому используйте их, например

 self.myDataArray = [NSMutableArray arrayWithCapacity:8];
 

или даже лучше

 NSMutableArray *tmpMyDataArray = [[NSMutableArray alloc] initWithCapacity:8];
self.myDataArray = tmpMyDataArray; 
[tmpMyDataArray release]; tmpMyDataArray = nil;
 

Комментарии:

1. аааА!!!!! Я только что много читал, чтобы найти проблему, с которой я столкнулся на прошлой неделе, из-за другой проблемы с памятью, созданной из-за многих сохранений, поэтому прочитайте все о том, как самостоятельно. это 1 и т. Д. … приветствую это! и снова я узнал что-то новое 🙂

2. о, и еще, почему второй пример лучше первого?

3. В нем более четко указано, когда мы хотим освободить память. Я считаю (я рад, что меня исправили по этому поводу), что автоматически выпущенная версия освободит память только в конце текущего цикла выполнения. В устройствах с ограниченным объемом памяти, таких как устройства iOS, полезно убедиться, что мы используем нашу память оптимально.