#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, полезно убедиться, что мы используем нашу память оптимально.