Objective-C 类的归档与解档:NSCoding 协议实现对象持久化存储

Objective-C 类的归档与解档:NSCoding 协议实现对象持久化存储

在 Objective-C 中,归档(Archiving)解档(Unarchiving) 是实现对象持久化存储的核心机制。通过遵循 NSCoding 协议,可将对象转换为二进制数据(归档),或从二进制数据重建对象(解档)。

一、核心协议:NSCoding

NSCoding 协议要求实现两个方法:

objectivec 复制代码
@protocol NSCoding
- (void)encodeWithCoder:(NSCoder *)coder;  // 归档方法
- (nullable instancetype)initWithCoder:(NSCoder *)coder; // 解档方法
@end
二、实现步骤
  1. 声明遵循协议(.h 文件):

    objectivec 复制代码
    #import <Foundation/Foundation.h>
    
    @interface Person : NSObject <NSCoding>
    @property (nonatomic, copy) NSString *name;
    @property (nonatomic, assign) NSInteger age;
    @end
  2. 实现协议方法(.m 文件):

    objectivec 复制代码
    @implementation Person
    
    // 归档:将属性编码为二进制数据
    - (void)encodeWithCoder:(NSCoder *)coder {
        [coder encodeObject:self.name forKey:@"name"];
        [coder encodeInteger:self.age forKey:@"age"];
    }
    
    // 解档:从二进制数据重建对象
    - (instancetype)initWithCoder:(NSCoder *)coder {
        self = [super init];
        if (self) {
            _name = [coder decodeObjectForKey:@"name"];
            _age = [coder decodeIntegerForKey:@"age"];
        }
        return self;
    }
    
    @end
三、关键数据类型处理
数据类型 归档方法 解档方法
对象类型(如 NSString) encodeObject:forKey: decodeObjectForKey:
基本类型(如 NSInteger) encodeInteger:forKey: decodeIntegerForKey:
浮点数(如 CGFloat) encodeFloat:forKey: decodeFloatForKey:
布尔值(BOOL) encodeBool:forKey: decodeBoolForKey:
结构体(如 CGRect) encodeCGRect:forKey: decodeCGRectForKey:
四、使用示例
  1. 归档对象(保存到文件):

    objectivec 复制代码
    Person *person = [[Person alloc] init];
    person.name = @"张三";
    person.age = 30;
    
    // 获取存储路径
    NSString *path = [NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES).firstObject stringByAppendingPathComponent:@"person.data"];
    
    // 归档并写入文件
    [NSKeyedArchiver archiveRootObject:person toFile:path];
  2. 解档对象(从文件读取):

    objectivec 复制代码
    NSString *path = ... // 同上路径
    Person *restoredPerson = [NSKeyedUnarchiver unarchiveObjectWithFile:path];
    NSLog(@"姓名: %@, 年龄: %ld", restoredPerson.name, (long)restoredPerson.age);
五、注意事项
  1. 键名一致性:归档和解档使用的键名必须完全一致
  2. 嵌套对象 :若属性是自定义对象,该对象也需实现 NSCoding
  3. 安全性扩展 :对于敏感数据,建议使用 NSSecureCoding(需实现 +supportsSecureCoding 方法)
  4. 性能优化:大量数据存储时,优先使用 Core Data 或 SQLite
六、应用场景
  • 用户配置信息的本地保存
  • 应用状态的持久化恢复
  • 离线数据缓存
  • 对象网络传输(需序列化)

通过 NSCoding 协议,开发者可以高效实现自定义对象的持久化存储,是 Objective-C 生态中数据本地化的基础解决方案。

相关推荐
开心就好20256 小时前
UniApp开发应用多平台上架全流程:H5小程序iOS和Android
后端·ios
开心就好20259 小时前
免 Xcode 的 iOS 开发新选择?聊聊一款更轻量的 iOS 开发 IDE kxapp 快蝎
后端·ios
恋猫de小郭12 小时前
Apple 的 ANE 被挖掘,AI 硬件公开,宣传的 38 TOPS 居然是"数字游戏"?
前端·人工智能·ios
忆江南1 天前
iOS 深度解析
flutter·ios
没有故事的Zhang同学1 天前
05-主题|事件响应者链@iOS-应用场景与进阶实践
ios
FeliksLv2 天前
尝试给Lookin 支持 MCP
ios
没有故事的Zhang同学2 天前
01-研究系统框架@Web@iOS | JavaScriptCore 框架:从使用到原理解析
ios
CocoaKier3 天前
苹果谷歌商店:如何监控并维护用户评分评论
ios·google·apple
iOS日常3 天前
iOS设备崩溃日志获取与查看
ios·xcode
wangruofeng4 天前
AI 助力 Flutter 3.27 升级到 3.38 完整指南:两周踩坑与实战复盘
flutter·ios·ai编程