在我的prepareForSegue
方法中,我将从NSUserDefaults检索到的不可变数组传递给DetailViewController可变字典属性。在修改数组之前是否需要创建数组的可变副本,还是在NSMutableDictionary类setter方法中自动生成?
我的代码......
ViewController.m
- (void)prepareForSegue:(UIStoryboardSegue *)segue sender:(id)sender
{
if ([segue.identifier isEqualToString:@"EditReminder"])
{
UINavigationController *navigationController = segue.destinationViewController;
DetailViewController *detailViewController = [[navigationController viewControllers] objectAtIndex:0];
detailViewController.delegate = self;
[detailViewController setTitle:@"Edit Reminder"];
// Pass ReminderData to detailVC if editing
NSIndexPath *selectedRowIndex = [self.tableView indexPathForSelectedRow];
NSArray *remindersArray = [[NSUserDefaults standardUserDefaults] objectForKey:@"reminders"];
detailViewController.reminderData = [remindersArray objectAtIndex: selectedRowIndex.row];
}
}
DetailViewController.h
@property (strong, nonatomic) NSMutableDictionary *reminderData;
DetailViewController.m
- (void)viewDidLoad
{
[super viewDidLoad];
if (self.reminderData) {
// Reminder data from user defaults is immutable. Create mutable copy.
// Is this necessary?
self.reminderData = [self.reminderData mutableCopy];
}
else {
self.reminderData = [[NSMutableDictionary alloc] init];
}
}
答案 0 :(得分:1)
是的,您肯定需要创建一个可变副本,如此处所示。如果将NSDictionary
(不可变)的实例分配给NSMutableDictionary
- 值属性,编译器可能不会抱怨,但调用存储对象上的任何变异方法都将导致运行时异常。语言或框架中没有任何魔法可以使不可变集合分配给可变类型变量自动变异。
另外,如另一个答案所述,您应该在第一次(在prepareForSegue
)中分配属性时执行可变副本,而不是在以后的时间。
答案 1 :(得分:1)
您需要创建可变副本,但您的实现是错误的。
在prepareForSegue
中,您需要执行mutableCopy
,或者您的财产中已存储了错误的对象。没有理由在viewDidLoad
中这样做,它可以被认为是一个错误。