Tij*_*Kez 2 properties exc-bad-access objective-c retain ios
我原以为'self.data ='会保留autorelease NSMutableArray对象和它包含的NSMutableDictionary对象,但最终我在表的cellForRowAtIndexPath方法尝试访问self.data中的NSDictionaries时得到EXC_BAD_ACCESS.
@property (strong, nonatomic) NSMutableArray *data;
- (void) updateReceivedData:(NSData *) jsonData
{
NSMutableArray *fetchedData = [NSJSONSerialization JSONObjectWithData:jsonData options:NSJSONReadingMutableContainers error:&error];
self.data = [self convertDates:fetchedData withFormat:kMySQLDateTimeFormat];
[self.tableView reloadData];
}
}
- (NSMutableArray*) convertDates:(NSMutableArray *) array withFormat:(NSString *) format
{
NSDateFormatter *dateFormatter = [[NSDateFormatter alloc] init];
[dateFormatter setDateFormat:format];
NSMutableArray *newArray = [NSMutableArray arrayWithArray:array];
for (NSMutableDictionary *dict in newArray)
{
for (id key in dict.allKeys)
{
if ([[dict objectForKey:key] isKindOfClass:[NSString class]])
{
NSString *value = [dict objectForKey:key];
NSDate *date = [dateFormatter dateFromString:value];
if (date) [dict setObject:date forKey:key];
}
}
}
[dateFormatter release];
return newArray;
}
Run Code Online (Sandbox Code Playgroud)
这里BAD_ACCESS抛出在NSLog之间.
- (UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath
{
static NSString *CellIdentifier = @"cell";
CustomCell *cell = [tableView dequeueReusableCellWithIdentifier:CellIdentifier];
if (cell == nil) {
NSLog (@"Cell was nil");
cell = [[[CustomCell alloc] init] autorelease];
}
NSDictionary *dict = [[NSDictionary alloc] init];
if (_isFiltered){
dict = [self.filteredData objectAtIndex:indexPath.row];
} else {
dict = [self.data objectAtIndex:indexPath.row];
}
NSLog (@"Filling Label 1");
cell.IDLabel.text = [[dict objectForKey:@"Id"] stringValue];
NSLog (@"Filling Label 2");
cell.firstNameLabel.text = [dict objectForKey:@"firstName"];
[dict release];
return cell;
}
Run Code Online (Sandbox Code Playgroud)
打开僵尸,看看它是否捕获了问题(EXC_BAD_ACCESS并不一定意味着过度释放的对象,但它可能).
对象的保留计数的绝对值会发生什么变化是无关紧要的.
但是,strong
如果通过setter分配(即self.data = ...而不是_data = ...),则属性意味着保留对象,是的.
归档时间: |
|
查看次数: |
558 次 |
最近记录: |