IOS中对象序列化与反序列化

Wesley13
• 阅读 890

概述

在IOS中,对象的序列化和反序列化分别使用NSKeyedArchiver和NSKeyedUnarchiver两个类,我们可以把一个类对象进行序列化然后保存到文件中,使用时再读取文件,把内容反序列化出来。这个过程通常也被称为对象的编码(归档)和解码(解档)。

需要注意的是,NSKeyedArchiver和NSKeyedUnarchiver是继承于NSCoder这个抽象类的,所以我们需要手动实现相应的编码方法和解码方法。

对象的序列化(编码、归档)

要把一个类对象归档,我们需要让这个类实现NSCoding协议,NSCoding协议是干嘛的,看头文件:

protocol NSCoding {
    
    func encodeWithCoder(aCoder: NSCoder)
    init(coder aDecoder: NSCoder) // NS_DESIGNATED_INITIALIZER
}

一个是编码方法:encodeWithCoder,参数便是NSCoder对象;另个是负责解码的构造函数。

我们有如下这个类:Person,分别实现了编码方法和解码方法:

class Person:NSObject,NSCoding{
    var name:String?
    var age:Int32?
    override init() {
    }
    required init(coder aDecoder: NSCoder) {
        self.name = aDecoder.decodeObjectForKey("name") as? String
        self.age = aDecoder.decodeInt32ForKey("age")
    }
    func encodeWithCoder(aCoder: NSCoder) {
        aCoder.encodeObject(self.name, forKey: "name")
        aCoder.encodeInt32(self.age!, forKey: "age")
    }
}

NSCoder的编码和解码方法也很简单,不同数据类型有自己的编码解码方法。详细的可以在Dash中查看。

现在可以使用NSKeyedArchiver类进行编码了:

//获得App的Document目录
let path = "~".stringByAppendingPathComponent("Documents").stringByStandardizingPath
//创建Person对象
var p = Person()
p.name = "lijialong"
p.age = 26
//进行归档,存放到Documents目录下的person.data文件中
let result = NSKeyedArchiver.archiveRootObject(p, toFile: path.stringByAppendingPathComponent("person.data")) //打印结果,成功返回true,失败返回false
println("result = \(result)")

打开Documents目录看下:

IOS中对象序列化与反序列化

使用编辑器打开这个文件,看不懂的一些乱码信息~:

IOS中对象序列化与反序列化

NSKeyedArchiver类除了能把对象归档到本地文件中,还能把对象转换为NSData类型,然后我们再使用NSData做一系列操作。

不管是归档到本地文件还是转换为NSData,操作的对象都要实现NSCoding接口哦!

//创建Person对象
var p = Person()
p.name = "lijialong"
p.age = 26
//获得NSData类型
let data = NSKeyedArchiver.archivedDataWithRootObject(p)

对象的反序列化(解码、解档)

反序列化的类无非就多了个un:

//从NSData中解码出对象
var person:Person? = NSKeyedUnarchiver.unarchiveObjectWithData(data) as? Person
//从一个文件中解码保存的对象
var person2:Person? = NSKeyedUnarchiver.unarchiveObjectWithFile(path) as? Person

总结

对象的归档解档,该对象都需要实现NSCoding协议。在一些简单的App中,可以使用这种方式快速保存一个对象。

tips:

本文由wp2blog导入,原文链接:http://devonios.com/ios-data-keyedarchiver.html

点赞
收藏
评论区
推荐文章
待兔 待兔
4个月前
手写Java HashMap源码
HashMap的使用教程HashMap的使用教程HashMap的使用教程HashMap的使用教程HashMap的使用教程22
Wesley13 Wesley13
3年前
java中的序列化
一、什么是java序列化  序列化:将对象写入IO流反序列化:从IO流中恢复对象序列化机制允许将实现序列化的java对象转换为字节序列,这些字节序列可以保存在磁盘上也可以通过网络传输,字节序列也可以再恢复为原来的对象。序列化机制可以让对象不依附于程序独立存在。二、应用场景
Wesley13 Wesley13
3年前
javaBean为什么要implements Serializable
一个对象序列化的接口,一个类只有实现了Serializable接口,它的对象才是可序列化的。因此如果要序列化某些类的对象,这些类就必须实现Serializable接口。而实际上,Serializable是一个空接口,没有什么具体内容,它的目的只是简单的标识一个类的对象可以被序列化。    什么情况下需要序列化:    1.     当
Wesley13 Wesley13
3年前
Java序列化(Serializable)与反序列化
序列化是干什么的简单说就是为了保存在内存中的各种对象的状态(也就是实例变量,不是方法),并且可以把保存的对象状态再读出来。虽然你可以用你自己的各种各样的方法来保存objectstates,但是Java给你提供一种应该比你自己好的保存对象状态的机制,那就是序列化。什么情况下需要序列化1.当你想把的内存中的对象状态保存到一个文件中
Wesley13 Wesley13
3年前
unity 序列化和反序列化
什么是序列化和反序列化(1)序列化是指把对象转换为字节序列的过程,而反序列化是指把字节序列恢复为对象的过程;. (2)序列化:对象序列化的最主要的用处就是在传递和保存对象的时候,保证对象的完整性和可传递性。序列化是把对象转换成有序字节流,以便在网络上传输或者保存在本地文件中。序列化后的字节流保存了对象的状态以及相关的描述信息。序列化机制
Wesley13 Wesley13
3年前
Java序列化——transient关键字和Externalizable接口
  提到Java序列化,相信大家都不陌生。我们在序列化的时候,需要将被序列化的类实现Serializable接口,这样的类在序列化时,会默认将所有的字段都序列化。那么当我们在序列化Java对象时,如果不希望对象中某些字段被序列化(如密码字段),怎么实现呢?看一个例子:import java.io.Serializable;imp
Wesley13 Wesley13
3年前
Java序列化技术即将被废除!!!
我们的对象并不只是存在内存中,还需要传输网络,或者保存起来下次再加载出来用,所以需要Java序列化技术。Java序列化技术正是将对象转变成一串由二进制字节组成的数组,可以通过将二进制数据保存到磁盘或者传输网络,磁盘或者网络接收者可以在对象的属类的模板上来反序列化类的对象,达到对象持久化的目的。如果你还不熟悉Java序列化技术,请详细阅读《关于Jav
Stella981 Stella981
3年前
FastJson 反序列化注意事项
问题描述使用fastJson对json字符串进行反序列化时,有几个点需要注意一下:反序列化内部类反序列化模板类0\.Getter/Setter问题如我们希望返回的一个json串为"name":"name","isDeleted":true,"isEmpty":1
Wesley13 Wesley13
3年前
unity将 -u4E00 这种 编码 转汉字 方法
 unity中直接使用 JsonMapper.ToJson(对象),取到的字符串,里面汉字可能是\\u4E00类似这种其实也不用转,服务器会通过类似fastjson发序列化的方式,将json转对象,获取对象的值就是中文但是有时服务器要求将传参中字符串中类似\\u4E00这种转汉字,就需要下面 publ
Stella981 Stella981
3年前
Protostuff一键序列化工具、Protobuf JAVA实现
前言:由于搜集网络,发现Protostuff相关内容较少,故此发布这篇文章1. 何为序列化序列化 (Serialization)将对象的状态信息转换为可以存储或传输的形式的过程。在序列化期间,对象将其当前状态写入到临时或持久性存储区。以后,可以通过从存储区中读取或反序列化对象的状态,重新创建该对象。序列化使其他代码可以查看或修改