我在NSUserDefault中保存了一个带有自定义对象的nsmutable数组。但是当我正在检索时,我得到了一个带有对象的数组,但是当我试图遍历对象时,应用程序崩溃并且在本地调试器中我得到了无效
CFStringRef和日志 - [消息标题]:无法识别的选择器发送到实例0x187900。
我的自定义对象遵循NSCoding协议,如果我打印出数组,则显示对象和以十六进制分配的内存。
我的消息。我已将名称更改为测试属性:
#import "Message.h"
@implementation Message
@synthesize tittel, adresse, dato;
static NSString *titleKey = @"title";
static NSString *urlKey = @"url";
static NSString *dateKey = @"date";
- (id)initWithCoder:(NSCoder *)decoder {
self = [super init];
if (self != nil) {
self.tittel = [decoder decodeObjectForKey:titleKey];
self.adresse = [decoder decodeObjectForKey:urlKey];
self.dato = [decoder decodeObjectForKey:dateKey];
}
return self;
}
- (void)encodeWithCoder:(NSCoder *)encoder {
[encoder encodeObject:self.tittel forKey:titleKey];
[encoder encodeObject:self.adresse forKey:urlKey];
[encoder encodeObject:self.dato forKey:dateKey];
}
-(void)dealloc{
[dato release];
[tittel release];
[adresse release];
[super dealloc];
}
@end
我保存并尝试检索对象的方法:
- (void)saveToFile:(NSMutableArray *)incoming {
NSUserDefaults *standardUserDefault = [NSUserDefaults standardUserDefaults];
if (standardUserDefault) {
[standardUserDefault setObject:[NSKeyedArchiver archivedDataWithRootObject:[NSArray arrayWithArray:incoming]] forKey:@"Messages"];
[standardUserDefault synchronize];
}
NSLog(@"Messages array saved. (%d message in array)",[incoming count]);
}
-(NSMutableArray*)returnFromFile{
NSUserDefaults *standardUserDefault = [NSUserDefaults standardUserDefaults];
NSData * dataCheck = [[NSData alloc]initWithData:[standardUserDefault objectForKey:@"Messages"]];
NSMutableArray *retro;
if(dataCheck != nil){
NSArray *load = [NSKeyedUnarchiver unarchiveObjectWithData:dataCheck];
if(load != nil){
retro = [NSMutableArray arrayWithArray:load];
}
else
retro = [[NSMutableArray alloc]init];
}
NSLog(@"Checking saved array (%d assignments in array)",[retro count]);
for(Message *m in retro){
NSLog(@"%@", m.tittel); //It crash here.
}
return retro;
}
答案 0 :(得分:0)
我解决了!
刚刚上了一堂课,几乎一样。唯一的区别是我使用了标准的init方法,我启动了所有的属性和initWithCoder。它奏效了。如果gcc发生错误或者我尝试编译一个不遵循继续显示相同错误的协议的类,则会发生这种情况。这有时它有助于创建完全相同的东西或与未成年人的差异和编译。看起来编译器并不总是刷新内存。