使用序列化和反序列化函数archivedDataWithRootObject和unarchivedObjectOfClasses的使用和遇到问题及解决方案

为何archiveRootObject和unarchiveObjectWithFile正常,而archivedDataWithRootObject和unarchivedObjectOfClasses一直报错。
[NSKeyedArchiver archiveRootObject:account toFile:path];和`c
PPAccountModel *account = [NSKeyedUnarchiver unarchiveObjectWithFile:path];


```c
'archiveRootObject:toFile:' is deprecated: first deprecated in iOS 12.0 - Use +archivedDataWithRootObject:requiringSecureCoding:error: and -writeToURL:options:error: instead
'unarchiveObjectWithFile:' is deprecated: first deprecated in iOS 12.0 - Use +unarchivedObjectOfClass:fromData:error: instead

替换很简单,但是会一堆问题等着你解决,序列化和反序列全失败。
先说能简单解决的序列化(归档):

    NSString *path = [self PathWithFileName:@"啊啊啊.data"];//拓展名可以自己随便取DYGlobleData.token = @"";PPAccountModel *account = nil;
//    [NSKeyedArchiver archiveRootObject:account toFile:path];NSError *error = nil;NSData *archiveData = [NSKeyedArchiver archivedDataWithRootObject:account requiringSecureCoding:YES error:&error];if (archiveData == nil || error) {NSLog(@"归档失败:%@", error);}BOOL isSuccess = [archiveData writeToFile:path atomically:YES];if(!isSuccess){NSLog(@"归档存储失败:%d", isSuccess);}

简单吧!也不是很复杂。首先失败的提示信息如下:

Error Domain=NSCocoaErrorDomain Code=4866 "未能写入数据,因为它的格式不正确。" UserInfo={NSUnderlyingError=0x2835675a0 {Error Domain=NSCocoaErrorDomain Code=4864 "This decoder will only decode classes that adopt NSSecureCoding. Class 'PPAccountModel' does not adopt it." UserInfo={NSDebugDescription=This decoder will only decode classes that adopt NSSecureCoding. Class 'PPAccountModel' does not adopt it.}}}

这是啥鬼?搞了半天查出来了,是序列化时采用了requiringSecureCoding为YES。但是序列化的类采用的是NSCoding协议,可以设置成NO,这样能序列化成功,但是反序列化就不能保证怎么样了。那就遵循NSSecureCoding协议吧!改造也很简单,在头文件换成NSSecureCoding,在实现文件写上supportsSecureCoding函数具体代码:

@interface PPAccountModel : NSObject<NSCoding>
+ (BOOL)supportsSecureCoding {return YES;
}

遇到空数组序列化失败:

[aCoder encodeObject:[NSMutableArray array] forKey:@"usersAvatar"];

修改为:

    if(isCommonUnitEmptyArray(self.usersAvatar)){[aCoder encodeObject:@"" forKey:@"usersAvatar"];}else{[aCoder encodeObject:self.usersAvatar forKey:@"usersAvatar"];}

也很简单啊!序列化搞定。
反序列化坑更多。序列化成功但是反序列化错误:
反序列化:

//得到用户信息
-(PPAccountModel *)getAccountInfo;
{FLDDLogDebug(@"函数");NSString *path = [self PathWithFileName:@"啊啊啊.data"];//拓展名可以自己随便取
//    PPAccountModel *account = [NSKeyedUnarchiver unarchiveObjectWithFile:path];// NSData转array,转dictionary,转NSStringNSError *err = nil;NSData *archiveData = [NSData dataWithContentsOfFile:path];if(!archiveData){return nil;}PPAccountModel *account = [NSKeyedUnarchiver unarchivedObjectOfClasses:[NSSet setWithArray:@[NSArray.class,NSDictionary.class, NSString.class, UIFont.class, NSMutableArray.class, NSMutableDictionary.class, NSMutableString.class, UIColor.class, NSMutableData.class, NSData.class, NSNull.class, NSValue.class,NSDate.class, XQUserModel.class, NSNumber.class, PPAccountModel.class, XQTimeMapModel.class]] fromData:archiveData error:&err];_account = account;if (archiveData == nil || err) {NSLog(@"反序列化失败:%@", err);}
//    if((account == nil) || (kUserLogin))NSLog(@"account = %@",account);if(account == nil){
//        [[NSUserDefaults standardUserDefaults] setBool:NO forKey:kLoginStateKey];
//        [[NSUserDefaults standardUserDefaults] removeObjectForKey:kLoginToken];
//        [[NSUserDefaults standardUserDefaults] synchronize];self.isLogin = NO;DYGlobleData.token = @"";[BITSingleObject sharedInstance].token = @"";}else{self.isLogin = YES;[BITSingleObject sharedInstance].token = account.token;DYGlobleData.token = account.token;[account fetchRoleData];}return account;
}

首先保证把参与序列化的所有对象类型都列举出来,写少了就4865 错误。但是全部列举万了还是4865错误,错误信息如下:

object c  -[NSKeyedUnarchiver decodeObjectForKey:]:    missing class information for object

到处查资料也没有查到解决方案,我试了半天我快放弃了,才找到原因。因为序列化的用户信息是反序列化后给单例对象了,这个用户信息增加了一些不需要序列化的成员变量,把它当用户相关的单例成员变量了,没有实现序列化和反序列化。我把这些变量去掉或序列化就反序列化正常了。
注意:子类的序列化和反序列化时需要把父类的变量也序列化和反序列化。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/9094.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Linux内核的PCI 框架

Linux内核的PCI框架是一个相对独立的子系统&#xff0c;负责管理PCI&#xff08;Peripheral Component Interconnect&#xff0c;外围设备互联&#xff09;硬件总线。该框架主要包括以下模块和功能&#xff1a; PCI核心框架&#xff1a;负责PCI总线的初始化&#xff0c;并提供…

自动驾驶数据标注有哪些?

自动驾驶汽车&#xff1a;人工智能(AI)的焦点 人工智能驱动汽车解决方案的市场规模预计到 2025年将增长十倍以上&#xff0c;提升车内体验的商机领域以及 AI 模型的无偏见训练数据的重要性。在本篇中&#xff0c;我们将介绍车外体验的关键组成部分&#xff0c;以及自动驾驶数据…

LLM 基础-transformers 库快速入门

一,Transformers 术语 1.1,token、tokenization 和 tokenizer1.2,input IDs1.3,attention mask1.4,bos_token、eop_token、pad_token、eos_token1.5,decoder models1.6,架构与参数二,Transformers 功能 API 概述三,快速上手 3.1,transformer 模型类别3.2,Pipeline&l…

React.js 中用于高质量应用程序的最佳实践和设计模式

原文&#xff1a;Best Practices and Design Patterns in React.js for High-Quality Applications&#xff0c;适当增删 原作者&#xff1a;Ori Baram 文章已获原文作者授权&#xff0c;禁止转载和商用 1. 构建可扩展的React应用程序最佳实践 1.1 目录结构 不按文件类型对组…

01背包相关题

题解&#xff1a;dp[j]表示目标和为j时的最大组合种数 class Solution { public:int dp[1005];int findTargetSumWays(vector<int>& nums, int target) {int val;int sum0;for(int i0;i<nums.size();i){sumnums[i];}int wsumtarget;if(w%21){return 0;}else{valw…

Java基础-泛型、形变和GC

Java基础-泛型、形变和GC 本文链接&#xff1a;https://blog.csdn.net/feather_wch/article/details/131948105 泛型、形变 1、Gson中TypeToken的作用是什么&#xff1f;是如何获得泛型的类型信息的&#xff1f; TypeToken利用匿名内部类会持有泛型的类型信息&#xff0c;在…

区间预测 | MATLAB实现QRGRU门控循环单元分位数回归多输入单输出区间预测

区间预测 | MATLAB实现QRGRU门控循环单元分位数回归时间序列区间预测 目录 区间预测 | MATLAB实现QRGRU门控循环单元分位数回归时间序列区间预测效果一览基本介绍模型描述程序设计参考资料 效果一览 基本介绍 MATLAB实现QRGRU门控循环单元分位数回归分位数回归多输入单输出区间…

微服务Day4——Docker

一、什么是Docker 微服务虽然具备各种各样的优势&#xff0c;但服务的拆分通用给部署带来了很大的麻烦。 分布式系统中&#xff0c;依赖的组件非常多&#xff0c;不同组件之间部署时往往会产生一些冲突。在数百上千台服务中重复部署&#xff0c;环境不一定一致&#xff0c;会…

npm 安装报错:源文本中存在无法识别的标记

npm install -g vue/cli 源文本中存在无法识别的标记。 所在位置 行:1 字符: 16 npm install -g <<<< vue/cli CategoryInfo : ParserError: (:) [], ParentContainsErrorRecordException FullyQualifiedErrorId : UnrecognizedToken 解决方…

064、故障处理之OMM_TiDB

oom 内存溢出&#xff0c;内存泄漏&#xff0c;相当于TiDB不能用了 TiDB Server OOM对业务的影响 TiDB Server上的业务SQL会失败业务响应时间升高前端体验变差 诊断方法 客户端应用 ERROR 2013(HY000): Lost connection to MySQL Server during query日志 dmesg -T | gr…

ARM——点灯实验

循环点灯 RCC寄存器使能GPIOE、GPIOF组寄存器 修改GPIOx组寄存器下的值 通过GPIOx_MODER寄存器设置为输出模式通过GPIOx_OTYOER寄存器设置为推挽输出类型通过GPIOx_OSPEEDR寄存器设置为低速输出通过GPIOx_PUPDR寄存器设置为禁止上下拉电阻点灯 通过GPIOx_ODR寄存器设置为高电…

excel中的vlookup如何实现根据多个条件查找?

目录 简述问题公式思路通用公式三条件查找公式实例 简述 Excel 中根据一个条件查找非常方便&#xff0c;Excel 提供了内置函数 VLOOKUP。但是实际中往往有多种情形&#xff0c;需要根据多个条件进行查找操作&#xff0c;目前没有现成的内置函数。 本篇介绍 VLOOKPCHOOSE 组合…

Craps赌博游戏问题C语言

说明一个简单的赌博游戏&#xff0c;游戏规则如下&#xff1a;玩家掷两个骰子&#xff0c;点数为1到6&#xff0c;如果第一次点数和为7或11&#xff0c;则玩家胜&#xff0c;如果点数和为2、3或12&#xff0c;则玩家输&#xff0c;如果和 为其它点数&#xff0c;则记录第一次的…

flask路由添加参数

flask路由添加参数 在 Flask 中&#xff0c;可以通过两种方式在路由中添加参数&#xff1a;在路由字符串中直接指定参数&#xff0c;或者通过 request 对象从请求中获取参数。 在路由字符串中指定参数&#xff1a;可以将参数直接包含在路由字符串中。参数可以是字符串、整数、…

Apipost使用教程

Apipost是一款集API调试、生成文档、Mock、测试于一体的协同工具。单个工具可以同时满足接口测试、生成/分享文档、Mock、流程测试等功能&#xff0c;还有超实用的多人多角色间实时协作的功能。将前端、后端、测试三种角色串联起来&#xff0c;从而实现工作流程无缝衔接、提高研…

Asp.Net 使用Log4Net (基础版)

Asp.Net 使用Log4Net (基础版) 1. 创建项目 创建ASP.NET Web Forms项目 在Visual Studio中创建一个新的ASP.NET Web Forms项目。命名为"Log4NetDemo"。 2.安装Log4Net包 打开NuGet包管理器控制台&#xff0c;并运行以下命令来安装Log4Net&#xff1a; mathemati…

(三)RabbitMQ七种模式介绍与代码演示

Lison <dreamlison163.com>, v1.0.0, 2023.06.22 七种模式介绍与代码演示 文章目录 七种模式介绍与代码演示四大交换机四种交换机介绍 工作模式简单模式&#xff08;Hello World&#xff09;工作队列模式&#xff08;Work queues&#xff09;订阅模式&#xff08;Publis…

FPGA设计时序分析一、时序路径

目录 一、前言 二、时序路径 2.1 时序路径构成 2.2 时序路径分类 2.3 数据捕获 2.4 Fast corner/Slow corner 2.5 Vivado时序报告 三、参考资料 一、前言 时序路径字面容易简单地理解为时钟路径&#xff0c;事实时钟存在的意义是为了数据的处理、传输&#xff0c;因此严…

基于Docker-compose创建LNMP环境并运行Wordpress网站平台

基于Docker-compose创建LNMP环境并运行Wordpress网站平台 1.Docker-Compose概述2.YAML文件格式及编写注意事项3.Docker-Compose配置常用字段4.Docker Compose常用命令5.使用Docker-compose创建LNMP环境&#xff0c;并运行Wordpress网站平台1. Docker Compose 环境安装下载安装查…

ChatGPT:人工智能交互的未来之光

一、ChatGPT&#xff1a;开启自然语言交流新纪元 ChatGPT 是基于 GPT&#xff08;生成式预训练&#xff09;技术的最新版本&#xff0c;它采用深度学习模型&#xff0c;通过在大规模文本数据上的预训练来理解自然语言&#xff0c;并生成具有连贯性和合理性的回复。ChatGPT 是一…