我在网站上发现了几个有类似问题的人的问题,但我仍然无法解决我的问题。事情就是这样:
我正在制作一个包含两个plist文件的iOS应用。当用户第一次打开应用程序时,应用程序负责将这两个文件移动到Documents目录。我知道这段代码有效,因为我随后可以从Documents目录路径中的每个文件中读取。但是,由于明显未知的原因,我无法写信给他们中的任何一个。这是我用来写第一个plist文件的代码:
+ (void)insertNewElementWith:(NSArray *)objects andKeys:(NSArray *)keys {
NSString *filePath = [self returnPathForFirstPlistFile];
NSMutableDictionary *contentOfFirstPlistFile = [[NSMutableDictionary alloc] initWithContentsOfFile:filePath];
NSDictionary *dictionary = [[NSDictionary alloc] initWithObjects:objects forKeys:keys];
[contentOfFirstPlistFile setObject:dictionary forKey:[NSNumber numberWithInt:[contentOfFirstPlistFile count]]];
[contentOfFirstPlistFile writeToFile:filePath atomically:YES];
[dictionary release];
}
returnPathForFirstPlistFile
确实有效,因为contentOfFirstPlistFile
包含{ }
而不是null
。但是,任何人都可以向我解释,为什么它会一直返回{ }
,即使已多次调用上述方法。
更新
以下是我用于将文件放在Documents目录中的代码。当用户通过应用登录时,placePlistsInDocumentsDirectory
仅 ,因此只会发生一次。
+ (NSString *)returnPathForFirstPlistFile {
NSArray *paths = NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES);
NSString *documentsDirectory = [paths objectAtIndex:0];
NSString *filePath = [documentsDirectory stringByAppendingPathComponent:@"First.plist"];
return filePath;
}
+ (NSString *)returnPathForSecondPlistFile {
NSArray *paths = NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES);
NSLog(@"%@", [paths objectAtIndex:0]);
NSString *documentsDirectory = [paths objectAtIndex:0];
NSString *filePath = [documentsDirectory stringByAppendingPathComponent:@"Second.plist"];
return filePath;
}
+ (void)placePlistsInDocumentsDirectory {
NSFileManager *fileManager = [NSFileManager defaultManager];
NSString *firstPlistPath = [self returnPathForFirstPlistFile];
NSString *secondPlistPath = [self returnPathForSecondPlistFile];
if (![fileManager fileExistsAtPath:firstPlistPath]) {
NSError *error;
NSString *bundle = [[NSBundle mainBundle] pathForResource:@"First" ofType:@"plist"];
[fileManager copyItemAtPath:bundle toPath:firstPlistPath error:&error];
}
if (![fileManager fileExistsAtPath:secondPlistPath]) {
NSError *error;
NSString *bundle = [[NSBundle mainBundle] pathForResource:@"Second" ofType:@"plist"];
[fileManager copyItemAtPath:bundle toPath:secondPlistPath error:&error];
}
}
答案 0 :(得分:2)
[NSNumber numberWithInt:[contentOfFirstPlistFile count]]
给你一个NSNumber对象。这不是字典的有效密钥,密钥必须是NSString。使用
[NSString stringWithFormat:@"%d",[contentOfFirstPlistFile count]]
相反。但是,如果您在字典中使用数字作为键,为什么不使用数组?
我试图自己重现这个问题,我唯一可以管理它的方法是使用没有字典作为根对象的plist。这返回了一个非零的字典,但不允许任何修改。然后无法将其写回文件。看看你之前的一些问题,你之前使用过基于数组的plist,所以这可能就是问题所在。