[英]mutating method sent to immutable object
第一次使用此方法時,它工作正常,但是第二次調用時,出現錯誤“將變異方法發送到不可變對象”。 問題出在“ addObject”命令上。
-(IBAction) save: (id) sender{
NSMutableArray *placesT= [[NSUserDefaults standardUserDefaults] objectForKey:@"placesT"];
if (!placesT) {
placesT=[[[NSMutableArray alloc] init] autorelease];
}
[placesT addObject: [NSString stringWithFormat:@"%@", tagF.text] ];
NSUserDefaults *tUD=[NSUserDefaults standardUserDefaults];
[tUD setObject:placesT forKey:@"placesT"];
[tUD synchronize];
[self dismissModalViewControllerAnimated:YES];
}
正如NSUserDefaults的文檔所述:“即使將可變對象設置為值,從NSUserDefaults返回的值也是不可變的。” 每當您要更改從NSUserDefaults獲得的集合時,都必須獲取不可變的版本,進行mutableCopy
,對其進行修改,然后再次將其重新設置。
這是因為存儲在NSUserDefaults中的對象不是mutableArray而是普通數組。
- (IBAction)save:(id)sender {
NSMutableArray *placesT = nil;
NSArray *tempArray = [[NSUserDefaults standardUserDefaults] objectForKey:@"placesT"];
if (tempArray) {
placesT = [tempArray mutableCopy];
} else {
placesT = [[NSMutableArray alloc] init];
}
[placesT addObject:[NSString stringWithFormat:@"%@", tagF.text]];
NSUserDefaults *tUD = [NSUserDefaults standardUserDefaults];
[tUD setObject:placesT forKey:@"placesT"];
[tUD synchronize];
[self dismissModalViewControllerAnimated:YES];
[placesT release];
}
placeT是一個不可更改的數組,可以始終將placesT
始終設置placesT
一個可變對象,也可以使用以下代碼。
NSMutableArray *placesT= [[[NSUserDefaults standardUserDefaults] objectForKey:@"placesT"] mutableCopy];
這應該工作:
-(IBAction)保存:(id)發件人{
NSMutableArray *placesT= [[NSMutableArray alloc]initWithArray:[[NSUserDefaults standardUserDefaults]
objectForKey:@“ placesT”]];
if (!placesT) { placesT=[[[NSMutableArray alloc] init] autorelease]; } [placesT addObject: [NSString stringWithFormat:@"%@", tagF.text] ]; NSUserDefaults *tUD=[NSUserDefaults standardUserDefaults]; [tUD setObject:placesT forKey:@"placesT"]; [tUD synchronize]; [self dismissModalViewControllerAnimated:YES]; }
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.