为了避免出现XY问题,以下是一些背景:
我的应用程序允许用户创建和保存很多设置,比如Xcode的字体和颜色选择器:

这是因为用户可以设置很多东西。只点击保存的设置就更容易了,而不是再次设置所有这些设置。
我使用Core数据来存储用户保存的设置。用户创建的每个设置都是一个NSManagedObject子类的实例。现在,我需要持久地存储所选设置,以便用户在应用程序重新打开时具有与以前相同的选择设置。
我的第一个想法是将NSManagedObject子类实例存储在NSUserDefaults中。但是根据文档,除非我把它转换成NSData,否则我不能存储它
默认对象必须是属性列表,即: NSData、NSString、NSNumber、NSDate、NSArray或NSDictionary的实例(或用于集合的实例组合)的实例。
然后,我尝试存储NSManagedObject子类实例的NSManagedObject。我看到有一个URIRepresentation()方法返回一个NSURL。所以我想这会成功的:
NSData(contentsOfURL: selectedOption!.objectID.URIRepresentation())但是初始化程序失败了。
现在我意识到这是一个愚蠢的想法,因为即使我可以将它转换为NSData,也不能将NSData转换回NSManagedObjectID!
根据这个问题,OP似乎能够存储对象id:
我将选定的主题objectID存储在NSUserDefaults中,以便当应用程序重新启动时,所选主题仍然完整。
我怎么能这么做?
发布于 2016-08-15 11:26:30
NSUserDefaults有“方便的方法”
public func setURL(url: NSURL?, forKey defaultName: String)
public func URLForKey(defaultName: String) -> NSURL?它允许存储和检索NSURL,就像URIRepresentation()获得的那样。与NSData之间的转换是透明的。来自文档
当使用
-[NSUserDefaults setURL:forKey:]存储NSURL时,会进行一些调整:
+[NSKeyedArchiver archivedDataWithRootObject:]来编写的。当使用-[NSUserDefaults URLForKey:]读取NSURL时,将使用以下逻辑:
+[NSKeyedUnarchiver unarchiveObjectWithData:]的参数。如果可以将NSData解压缩为NSURL,则返回NSURL,否则将返回nil。因此,将托管对象ID保存为
NSUserDefaults.standardUserDefaults().setURL(object.objectID.URIRepresentation(),
forKey: "selected")并检索对象ID和对象,例如:
if let url = NSUserDefaults.standardUserDefaults().URLForKey("selected"),
let oid = context.persistentStoreCoordinator!.managedObjectIDForURIRepresentation(url),
let object = try? context.existingObjectWithID(oid) {
print(object)
// ...
}有关保存所选设置的其他方法,请参见上述评论。
https://stackoverflow.com/questions/38953560
复制相似问题