2013-05-30 82 views
0

我有一个问题,我不能让我的头。我有一个NSUserDefaults的实例,并在那里存储了一些值。其中一个值是一个数组,其中包含要在另一个显示中使用的玩家分数(其游戏)。游戏结束后,我用新分数更新阵列并将其重新分配给NSUserDefaults,但出于某种原因,它似乎没有正确运行,并且在调试时我尝试将计数打印到控制台中,但始终0NSUserDefaults数组没有正确保存

这里是有问题的代码:

// // SAMHighScoreInputViewController.m // Tappity // // Created by Sam on 29/05/13. // Copyright (c) 2013 Sam. All rights reserved. // 

#import "SAMHighScoreInputViewController.h" 
#import "SAMScoreObject.h" 

@interface SAMHighScoreInputViewController() 

@end 

@implementation SAMHighScoreInputViewController 

- (id)initWithNibName:(NSString *)nibNameOrNil bundle:(NSBundle *)nibBundleOrNil { 
    self = [super initWithNibName:nibNameOrNil bundle:nibBundleOrNil]; 
    if (self) { 
     // Custom initialization 
    } 
    return self; } 

- (void)viewDidLoad { 
    self.defaults = [NSUserDefaults standardUserDefaults]; 
    self.nameScoreLabel.text = [NSString stringWithFormat:@"%@ - %@", [self.defaults objectForKey:@"lastName"], [self.defaults objectForKey:@"lastScore"]]; 
    self.nameTextField.text = [self.defaults objectForKey:@"lastName"]; 

    [super viewDidLoad]; // Do any additional setup after loading the view. } 

- (void)didReceiveMemoryWarning { 
    [super didReceiveMemoryWarning]; 
    // Dispose of any resources that can be recreated. } 





- (IBAction)textFieldValueChanged:(UITextField *)sender { 

    self.nameScoreLabel.text = [NSString stringWithFormat:@"%@ - %@", self.nameTextField.text, [self.defaults objectForKey:@"lastScore"]]; 
    } 

- (IBAction)submitButtonTapped:(UIButton *)sender { 



    SAMScoreObject *score = [[SAMScoreObject alloc] init]; 

    score.playerName = self.nameTextField.text; 
    score.score = [self.defaults integerForKey:@"lastScore"]; 



    NSArray *scores = [self.defaults objectForKey:@"scoresArray"]; 

    NSMutableArray *updatedArray = [scores mutableCopy]; 

    [updatedArray addObject:score]; 

    NSArray *updatedArrayScores = [updatedArray copy]; 

    [self.defaults setObject:updatedArrayScores forKey:@"scoresArray"]; 

    [self.defaults setObject:[self.defaults objectForKey:@"scoresArray"] forKey:@"scoresArray"]; 

    [self.defaults synchronize]; 


    NSLog(@"%@, %@", [self.defaults objectForKey:@"lastScore"], [self.defaults objectForKey:@"lastName"]); 
    NSLog(@"%i", [[self.defaults objectForKey:@"scoresArray"] count]); 


    [self dismissViewControllerAnimated:YES completion:nil]; 
    } @end 
+0

我没有看到错误,但我建议对代码进行两项改进:1)将数组的另一个副本并将其分配给'updatedArrayScores'的步骤是不必要的,只需将'updatedArray'直接传递给' NSUserDefaults'。 2)你可以完全删除语句'[self.defaults setObject:[self.defaults objectForKey:@“scoresArray”] forKey:@“scoresArray”];'。 – herzbube

+0

'self.defaults'设置属性如何?你确定保留它。如果它没有被保留,那么在你发送'setObject:forKey:'和'synchonize'方法之前它可能已经被释放,并且它会失败。 – lukestringer90

回答

1

哪里scoresArray有史以来?当你尝试更新它时,你可能应该懒洋洋地创建它。例如:

NSArray *scores = [self.defaults objectForKey:@"scoresArray"]; 
if(scores == nil) 
{ 
    scores = [NSArray array]; 
} 
NSMutableArray *updatedArray = [scores mutableCopy]; 
+0

种类已经在一定程度上做了这些,但这并没有解决问题,感谢您的帮助思想。 – flux

2

需要序列您SAMScoreObject成某种形式的NSData对象之前,你可以把它存储在NSUserDefaults商店。

documentation

默认对象必须是一个属性列表,即,(或对集合的实例的组合)的实例:NSData的,的NSString,的NSNumber,NSDate的,NSArray中,或NSDictionary。如果你想存储任何其他类型的对象,你通常应该将其存档以创建一个NSData实例。

您存储NSArray对象的事实不够好,因为该数组中的对象不是支持的类型之一。

+0

这似乎是事情不起作用的最合理的原因。 – lukestringer90