有趣的问题!我一直支持 iOS 10.0,所以在看到这个之前我还没有遇到过这样的问题。我折腾了一个小时,成功找到了问题所在。
使用较新的版本可能导致 IF 语句返回 FALSE 的原因
代码?
这是因为你的unarchivedObject
对象是nil!
如果您使用参数error
在新方法中,您会看到如下错误:
错误域 = NSCocoaErrorDomain 代码 = 4864 “此解码器只会
解码采用 NSSecureCoding 的类。 'QTPerson' 类没有
采用它。" UserInfo={NSDebugDescription=此解码器只会解码
采用 NSSecureCoding 的类。 'QTPerson' 类不采用它。
但是我们如何获得正确的值呢unarchivedObject
而不是零?这需要几个步骤。
首先,让你的模型/类符合<NSCoding, NSSecureCoding>
例子:QTPerson.h
#import <Foundation/Foundation.h>
@class QTPerson;
NS_ASSUME_NONNULL_BEGIN
#pragma mark - Object interfaces
@interface QTPerson : NSObject <NSCoding, NSSecureCoding>
@property (nonatomic, copy) NSString *text;
@end
NS_ASSUME_NONNULL_END
然后实现协议方法:
QTPerson.m
#import "QTPerson.h"
@implementation QTPerson
+ (BOOL)supportsSecureCoding {
return YES;
}
- (void)encodeWithCoder:(NSCoder *)coder {
[coder encodeObject:_text forKey:@"text"];
}
- (instancetype)initWithCoder:(NSCoder *)coder {
self = [super init];
if (self) {
_text = [coder decodeObjectOfClass:[NSString class] forKey:@"text"];
}
return self;
}
@end
然后在归档对象时,您需要传递YES
到参数requiringSecureCoding
,像这样:
QTPerson *person = [[QTPerson alloc] init];
person.text = @"Glenn";
NSData *codedData1 = [NSKeyedArchiver archivedDataWithRootObject:person requiringSecureCoding:YES error:nil];
[[NSUserDefaults standardUserDefaults] setValue:codedData1 forKey:@"boom"];
最后,当取消存档时,只需执行正确的操作即可,如下所示:
NSData *codedData = [[NSUserDefaults standardUserDefaults] dataForKey:@"boom"];
NSError *er;
id unarchivedObject=[NSKeyedUnarchiver unarchivedObjectOfClass:[QTPerson class] fromData:codedData error:&er];
if([unarchivedObject isKindOfClass:[QTPerson class]]){
NSLog(@"TRUE!");
} else {
NSLog(@"FALSE!");
}
瞧!你会得到非空对象unarchivedObject
,因此是您正在寻找的 TRUE/YES 值!