首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

在NSUserDefaults中的NSMutableArray中存储自定义对象

在iOS开发中,NSUserDefaults 是一个用于存储应用程序的配置信息和首选项的便捷方式。NSMutableArray 是一个可变数组,可以在运行时动态地添加和删除元素。然而,NSUserDefaults 只能存储属性列表(plist)对象,如字符串、数字、数组、字典等。要在 NSUserDefaults 中存储自定义对象,需要将其转换为可以序列化的格式,例如 NSData 或使用 NSKeyedArchiver 进行归档。

以下是一个简单的示例,说明如何在 NSUserDefaultsNSMutableArray 中存储自定义对象:

  1. 创建一个自定义对象,例如一个名为 Person 的类,包含 nameage 属性。
代码语言:objc
复制
@interface Person : NSObject <NSCoding>
@property (nonatomic, strong) NSString *name;
@property (nonatomic, assign) NSInteger age;
- (void)encodeWithCoder:(NSCoder *)encoder;
- (instancetype)initWithCoder:(NSCoder *)decoder;
@end

@implementation Person
- (void)encodeWithCoder:(NSCoder *)encoder {
    [encoder encodeObject:self.name forKey:@"name"];
    [encoder encodeInteger:self.age forKey:@"age"];
}

- (instancetype)initWithCoder:(NSCoder *)decoder {
    self = [super init];
    if (self) {
        self.name = [decoder decodeObjectForKey:@"name"];
        self.age = [decoder decodeIntegerForKey:@"age"];
    }
    return self;
}
@end
  1. 将自定义对象归档为 NSData 对象,并将其添加到 NSMutableArray 中。
代码语言:objc
复制
Person *person = [[Person alloc] init];
person.name = @"John Doe";
person.age = 30;

NSMutableArray *array = [[NSMutableArray alloc] init];
NSData *personData = [NSKeyedArchiver archivedDataWithRootObject:person];
[array addObject:personData];

[[NSUserDefaults standardUserDefaults] setObject:array forKey:@"peopleArray"];
[[NSUserDefaults standardUserDefaults] synchronize];
  1. NSUserDefaults 中获取 NSMutableArray,并解档自定义对象。
代码语言:objc
复制
NSData *dataArray = [[NSUserDefaults standardUserDefaults] objectForKey:@"peopleArray"];
NSMutableArray *array = [NSKeyedUnarchiver unarchiveObjectWithData:dataArray];

for (NSData *personData in array) {
    Person *person = [NSKeyedUnarchiver unarchiveObjectWithData:personData];
    NSLog(@"Name: %@, Age: %ld", person.name, (long)person.age);
}

请注意,这个示例使用了 NSCoding 协议和 NSKeyedArchiver 来序列化和反序列化自定义对象。这种方法可以在 NSUserDefaults 中存储复杂的自定义对象。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

在Cookie中存储对象

中,但因为Cookie中只能存储字符串,所以想到了先把用户实体序列化成Json串,存储在Cookie中,用到的时候再拿出来反序列化。...(我的开发环境为VS2012,.net framework版本为4.0,) C#中Json与对象之间的互相转换 ---- 下载并引用Newtonsoft.Json.dll 定义一个简单的用户实体: public...">Json字符串 /// 要生成的对象类型 /// 反序列化后的对象 public static...,序列化的字符串存储到Cookie中时会产生乱码,为了防止产生乱码,我们在存入Cookie之前先用UrlEncode()和UrlDecode()对Json串进行编码与解码。...而且,一般的浏览器支持的Cookie存储的容量为4k(差也就差一两个字节),足够存储一个经过序列化的对象了。

3.8K40
  • set中如何存储自定义对象?

    如何在set中存储自定义对象? set是什么 假设你已经在C++中使用过set,那么你应该知道,set中存储的元素是去重的。...如何在set中存储自定义对象 有时候,我们可能想通过set做一下去重的事情,对于基本数据类型,set都能很好地处理。我们看看对于自定义的对象,它的结果如何呢?...调用原则 其实,set容器在判定已有元素a和新插入元素b是否相等时,是这么做的: 将x作为左操作数,y作为右操作数,调用比较函数,并返回比较值 将x作为左操作数,y作为右操作数,再调用一次比较函数,并返回比较值...} else { return this->id > a.id; } } 添加之后,重新运行,就符合预期,可以对自定义对象去重啦...总结 对于自定义对象存储在set中,如果我们希望它按照我们指定的规则去重,就可能需要重载operator<了,那么是不是只有这一种方法呢?

    1.9K30

    iOS开发——数据持久化之归档

    在实际的项目开发中,数据持久化是我们必须要考虑的一个事情,如何把我们需要的数据进行持久化处理。...而昨天我在实际工作中,有一个数组NSMutableArray需要存储,但是使用时,报了一个错误 reason: '*** -[NSUserDefaults setObject:forKey:]: attempt...后来发现我的数组中的对象,是Model类的对象。 既然涉及到了Model类的对象,就要考虑用归档(NSKeyedArchiver)来处理它了。...NSKeyedArchiver能够存储的数据范围很广,因为它对应着MVC中的Model层,即实体类。在程序中,我们会在Model层定义很多的entity,例如name、room、device等。...要使对象可以归档,对象必须实现NSCoding协议,大部分对象都符合NSCoding的协议,一般我们可以在我们的Model类中实现NSCoding协议。

    62010

    在.NET中调用存储过程

    因为做项目要用到数据库,因此存储过程是必不可少的,看了一点如何在.NET中调用存储过程的资料,颇有点心得,觉得这个东西是当用到数据库的时候必须要会的一项技术。...下面是它的定义: 存储过程(Stored Procedure)是一组为了完成特定功能的SQL语句集,经编译后存储在数据库中。用户通过指定存储过程的名字并给出参数(如果该存储过程带有参数)来执行它。...存储过程是数据库中的一个重要对象,任何一个设计良好的数据库应用程序都应该用到存储过程。....NET中调用存储过程。...在VS2005里面新建一个控制台程序,新建一个方法如下: public void nopara() { SqlConnection con = new SqlConnection

    2.2K10

    在控制流中存储数据

    如果做得好,将存储在数据中的程序状态存储在控制流中,可以使程序比其他方式更清晰、更易于维护。 在说更多之前,重要的是要注意并发性不是并行性。...不管名称如何,这篇文章的基本观点是,根据多个独立执行的控制流编写程序,允许您将程序状态存储在一个或多个控制流的执行状态中,特别是在程序计数器(该部分正在执行的行)和堆栈上。...这个程序如此不透明的主要原因是它的程序状态被存储为数据,特别是在名为 state 的变量中。当可以在代码中存储状态时,这通常会导致程序更清晰。...在这些情况下,调用方一次传递一个字节的输入序列意味着在模拟原始控制流的数据结构中显式显示所有状态。 并发性消除了程序不同部分之间的争用,这些部分可以在控制流中存储状态,因为现在可以有多个控制流。...我的下一篇文章“Coroutines for Go”扩展了这个想法。 局限性 这种在控制流中存储数据的方法不是万能的。

    2.5K31

    在 JavaScript 中如何克隆对象?

    ,则我们对一个变量所做的任何更改也将反映在另一个变量中,因为两个变量都指向同一对象。...若要克隆对象,请使用 Object.assign() 方法,该方法会将一个或多个源对象的所有可枚举属性的值复制到目标对象,但是此方法仅对对象的一个浅拷贝。...与浅拷贝不同,深拷贝以递归方式复制每个子对象,直到所有涉及的对象都被复制为止。 我们可以使用什么方法复制对象的深层副本?...我们创建了一个deepClone(object)函数,将想要克隆的对象作为参数传递给它。在函数内部,将创建一个局部变量克隆,这是一个空对象,其中将从起始对象克隆的每个属性都将添加到该对象中。...具体思路: 如果该属性不是对象,则将其简单地克隆并添加到新的克隆对象中。

    4.6K20

    JVM之对象在堆中的流转

    JVM之对象在堆中的流转 对象优先在 Eden 区分配:大多数情况下,对象在新生代 Eden 区分配,当 Eden 区空间不够时,发起 Minor GC。...大对象直接进入老年代:大对象是指需要连续内存空间的对象,最典型的大对象是那种很长的字符串以及数组。经常出现大对象会提前触发垃圾收集以获取足够的连续空间分配给大对象。...-XX:PretenureSizeThreshold,大于此值的对象直接在老年代分配,避免在 Eden 区和 Survivor 区之间的大量内存复制。...长期存活的对象终将进入老年代:为对象定义年龄计数器,对象在 Eden 出生并经过 Minor GC 依然存活,将移动到 Survivor 中,年龄就增加 1 岁,增加到一定年龄则移动到老年代中。...空间分配担保 (1)在发生 Minor GC 之前,虚拟机先检查老年代最大可用的连续空间是否大于新生代所有对象总空间,如果条件成立的话,那么 Minor GC 可以确认是安全的; (2)如果不成立的话,

    8010

    腾讯云存储最佳实践系列二:对象存储中配置自定义域名支持 HTTPS 访问

    对象存储中配置自定义域名支持 HTTPS 访问 用户可通过自有域名(自定义域名,如test.cos.com)访问存储桶(Bucket)下的对象(Object)。...具体操作指引如下: · 开启 CDN 加速时配置自定义域名支持 HTTPS 访问 · 关闭 CDN 加速时配置自定义域名支持 HTTPS 访问 开启 CDN 加速 一、绑定自定义域名 将存储桶绑定到您的自有域名...关闭 CDN 加速 本章节主要以示例的形式介绍在 COS 中通过反向代理配置自定义域名(关闭 CDN 加速)支持 https 访问的操作步骤。...本示例将实现不开启 CDN 加速的情况下,直接通过自定义域名https://test.cos.com访问用户 APPID 为 12345678 、所属地域为华南、名称为 testhttps 的存储桶,具体操作步骤如下...进阶配置 通过浏览器直接打开网页 在配置好自定义域名支持 HTTPS 访问后,就可以通过您的域名下载存储桶(Bucket)中的对象(Object)了。

    4.6K11

    如何在CVM实例中访问对象存储

    概述CDC中的对象存储,如果在CVM实例中使用,需要先做好域名解析、权限配置等工作。1. 对象存储打通子网对象存储服务与客户的VPC打通,需要客户先确认在哪个子网中使用。...由腾讯云工程师进行网络配置,会在客户指定的子网中配置一个vip并与对象存储打通并映射。如果客户要在多个子网中使用使用对象存储,建议通过ACL、安全组的配置,将该vip与其他子网打通。2.....myqcloud.com这样的格式,还请指导一下。3. 存储桶权限配置CDC中对象存储默认是私有读写权限,客户可以通过API的方式进行访问。...但是客户如果要用对象文件的网络地址直接下载,则需要添加匿名访问权限,操作如下。l 打开存储桶,进入 「Policy权限设置」 页面l 点击页面中 Policy权限设置 中的 添加策略 链接。...因为CDC里的对象存储没有配置https,所以需要把工具切换到http。l 找到配置文件,windows一般在 C:\Users\目录下,linux一般在~/.cos.yaml。

    3.4K40

    动态代理对象在 IronPython 中的实现

    1、问题背景在 IronPython 中,有时我们需要创建一个动态代理对象,以便在运行时动态呈现底层结构。这个代理对象本身不应该有任何函数和属性,我们希望捕获运行时中的所有调用。...捕获函数调用很容易,我们只需要为对象定义一个 getattr() 函数,检查底层层中是否存在适当的函数,并返回一些类似函数的对象。...我们还尝试在对象中即时创建属性,结合使用 exec() 和内置的 property() 函数,但发现 IronPython 1.1.2 缺少整个 'new' 模块(在 IronPython 2.x beta...CallProxy 类将一个可调用对象包装在一个对象中,以便在调用时执行这个可调用对象。ObjProxy 类代理对象拦截属性访问,并在访问时返回相应的属性或方法。...这种方式在 IronPython 中实现了动态代理对象,可以灵活地拦截和处理方法调用。根据需要,可以在包装器函数中添加更多的逻辑,如日志记录、权限检查等。

    11810

    详解使用对象存储服务备份NAS中的数据

    文章目录[隐藏] 0.前言 1.什么是对象存储 2.购买资源包 3.创建访问密钥 4.新建存储桶 5.设置群晖使用对象存储 6.计费模式说明 0.前言 对数据备份有所了解的朋友应该都听说过“两地三中心”...但就现实情况而言,对于多数人而言在异地放置一台 NAS 无异于天方夜谭,于是选择由第三方提供的存储服务便成为了仅有的可行方案。 在现有的云存储方案中,接受度最高也最为普及的莫过于网盘服务了。...下面便以腾讯云对象存储(COS)和群晖 DSM 6.2 为例,详细介绍如何使用对象存储服务备份 NAS 中的数据。...4.新建存储桶 存储桶可以理解为对象存储中的不同分区,在腾讯云后台进入对象存储,依次选择:存储桶列表 – 创建存储桶。...标准存储一般不涉及取回费用,部分服务商的低频和归档在需要取回数据时需要进行解冻,会产生取回费用。 最后流量费用则是从服务商下载对象存储中的文件所产生的流量的费用。

    4.5K20

    数据湖存储在大模型中的应用

    本次巡展以“智算 开新局·创新机”为主题,腾讯云存储受邀分享数据湖存储在大模型中的应用,并在展区对腾讯云存储解决方案进行了全面的展示,引来众多参会者围观。...会中腾讯云高级产品经理林楠主要从大模型的发展回顾、对存储系统的挑战以及腾讯云存储在大模型领域中的解决方案等三个角度出发,阐述存储系统在大模型浪潮中可以做的事情。...同时在OpenAI的研究中,研究人员也发现:在使用相同数量的计算资源进行训练时,更大的模型可以在更少的更新次数后达到最优的性能;模型性能随着训练数据量、模型参数规模的增加呈现幂律增长趋势。...在存储视角下,我们回顾大模型整体技术框架中会涉及存储诉求的环节: 数据采集环节。通过对象存储的海量分布式存储和高可用的公网接入能力,支持多种不同来源的结构化、半结构化、非结构化数据的快速接入。...基于腾讯云自研的分布式对象存储引擎Yotta,它可支持单集群1万台服务器,单集群百EB级的存储;对象存储也提供了丰富的数据生命周期管理能力,可以很低成本地存储海量的公开数据集。

    55420

    谈谈集群NAS在VDI存储中的应用

    S君小故事:存储选型难在何处?S君是一家公司的存储工程师,每当业务部门提出新的存储设备需求时,他就要配合系统架构师共同确定产品方案。这可不只是数据库放在SAN、共享文件放NAS那么简单。...根据我们的理解,存储选型的关键大致有以下几点: ✎充分理解业务需求;✎了解候选供应商的产品、技术特点;✎新设备能否良好兼容现有IT环境中的设备?...在满足用户现有需求的基础上,如果能提供未来扩展空间(容量/性能)也是一个有吸引力的地方。 在VDI应用中,集群NAS是否比传统单/双控NAS更好?它能够提供那些更多的价值?...员工的虚拟桌面获得更好的响应能力,在Citrix XenDesktop环境中的应用明显运行地更快。“作为迁移到戴尔Compellent存储的一个收益,我们看到20%的应用性能提升”,他表示。...如上图,在业界标准的SPECsfs NFS性能测试中,戴尔FS8600根据设备数量的配置不同,在2控、4控和8控的情况下,分别测得131,684、254,412和494,244每秒文件操作数(OPS)

    2.5K60

    Solidigm:NVMe SSD 在AI存储中的价值

    全文概览 文章探讨人工智能和机器学习(AI/ML)数据管道中的存储解决方案,强调了固态硬盘(SSD)尤其是NVMe SSD在不同阶段的应用价值。...在这张表中,基于 FIO 的性能分析是通过执行不同的读写操作类型来测量存储设备在 AI/ML 工作负载中的表现。...这些数据帮助评估不同存储方案在 AI/ML 场景中的适用性。...在全闪存高性能层中,支持较低性能的 HDD在这个层次,SSD 主要作为高性能存储,与较低性能的硬盘(HDD)共同工作。...On-Prem(本地): 右图 GPU 服务器与全 QLC 对象存储层在本地部署中,GPU 服务器通过 SSD 存储与全 QLC(四层单元)对象存储层进行数据交互。

    13300

    BIT类型在SQL Server中的存储大小

    对于一般的INT、CHAR、tinyint等数据类型,他们占用的存储空间都是以Byte字节为单位的,但是BIT类型由于只有0和1或者说false和true,这种情况只需要一个Bit位就可以表示了,那么在...例如这样一个表: CREATE TABLE tt ( c1 INT PRIMARY KEY, c2 BIT NOT NULL, c3 CHAR(2) NOT NULL ) SQL Server在存储表中的数据时先是将表中的列按照原有顺序分为定长和变长...在数据页中存储数据时先存储所有定长的数据,然后再存储变长的数据。...关于数据行的具体格式我就不在这里多说了,在《SQL Server 2005技术内幕 存储引擎》中有详细介绍。我们插入的数据从第5个字节开始,是01000000 016161。...3.一个表中有多个BIT类型的列,其顺序是否连续决定了BIT位是否可以共享一个字节。SQL Server中按照列顺序存储,第一列和最后一列都是BIT数据类型列,不可以共用一个字节。

    3.5K10

    JDBC:数据库自定义类型与Java类的映射—将对象存储在关系数据库中(一)

    最近在使用PostgreSQL数据库,PostgreSQL中可以自定义自己的数据类型。 那怎么利用JDBC将Java类与PostgreSQL数据库中自己定义的类型关联起来呢。...即怎么将Java对象存储在数据库中呢。我这里说的对象的存储不是讲对象序列化了以二进制的方式进行的存储,我说的是不经过序列化直接进行的存储。因为数据库中有Java对象对应的自定义类型。...下面先总结下步骤: 1.在数据库中自定义数据类型(CREATE TYPE TypeName AS) 2.在Java中新建对应的JavaBean,继承SQLData类,并实现其中的一些方法 3.利用数据库连接对象的...setTypeMap方法设置数据库自定义类型和JavaBean的映射。...详细步骤见下篇博客JDBC:数据库自定义类型与Java类的映射—将对象存储在关系数据库中(二)。

    8.3K40

    JAVA对象在JVM中内存分配

    java实例对象在内存中的分配情况。...java对象在内存中的关系 图画的稍微有点问题,不过能说明对象在内存中的大致位置。 从图中我们可以看出,普通的java实例对象内存分配,主要在这三个区域:虚拟机栈、堆、方法区。...从内存区域来分析 虚拟机栈:只存放局部变量 堆:存储对象的实例 方法区:存放Class信息和常量信息。...从变量的角度来分析 局部变量:存放在虚拟机栈中(具体应为[栈->栈帧->局部变量表]) 基本类型的值直接存在栈中。如age=10 如果是对象的实例,则只存储对象实例的引用。...如果常量的类型是对象的实例则只存储对象实例的引用地址 通过变量的角度来分析,我们就可以了解为什么静态变量不用new就能调用,而实例变量必须new出对象,才能调用。

    1.8K120
    领券