具有自定义对象无效属性的NSMutableArray

时间:2011-09-16 11:59:31

标签: iphone nsstring nsuserdefaults nsobject nscoding

我在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;

}

1 个答案:

答案 0 :(得分:0)

我解决了!

刚刚上了一堂课,几乎一样。唯一的区别是我使用了标准的init方法,我启动了所有的属性和initWithCoder。它奏效了。如果gcc发生错误或者我尝试编译一个不遵循继续显示相同错误的协议的类,则会发生这种情况。这有时它有助于创建完全相同的东西或与未成年人的差异和编译。看起来编译器并不总是刷新内存。