swift4.1 编解码

简介: /*本节来学习swift的编码、解码和串行化。为什么需要编解码?许多的编程任务涉及到通过网络发送数据、将数据保存到磁盘上,或是将数据提交到API以及服务上。

/*
本节来学习swift的编码、解码和串行化。

为什么需要编解码?
许多的编程任务涉及到通过网络发送数据、将数据保存到磁盘上,或是将数据提交到API以及
服务上。这些任务往往需要将数据进行编码到一个中间格式然后在进行传输,或是在传输结束后将中间格式转换回
原始数据,然后在进行处理。这就需要提供一种能方便对数据进行编码、解码的机制了。

原始数据---编码---提交传输----解码----原始数据

swift 提供了标准化的方法对数据进行编码和解码。
编码: Encodable协议
解码: Decodable协议
如果自定义类型要同时遵循Encodable与Decodable协议,就可以直接用 Codable 协议。

Apple的Foundation库提供了两种编码器类,分别是 JSONEncoder / JSONDecoder,
PropertyListEncoder / PropertyListDecoder

JSONEncoder / JSONDecoder: 对象实例与json数据格式之间进行转换;
PropertyListEncoder / PropertyListDecoder: 对象实例与XML数据格式之间进行互相转换。
*/

do {

struct MyObject: Codable {
    var a = 10
    var str = "Hello"
    var array = [1, 2, 3]
}

let obj = MyObject()
// 将obj转为JSON字符串
let encoder = JSONEncoder()
// 注意,JSONEncoder的encoder方法返回的是一个Data类型的对象
let jsonData = try? encoder.encode(obj)

if let jsonData = jsonData,
    let jsonStr = String(data: jsonData, encoding: .utf8) {
    print("Json string is : \(jsonStr)")
}

// 以下是将一个json data转为MyObject对象
let decoder = JSONDecoder()
let newObj = try? decoder.decode(MyObject.self, from: jsonData!)
if let obj = newObj {
    print("a = \(obj.a)")
    print("str = \(obj.str)")
    print("array = \(obj.array)")
}

}

// 将自定义类型转为XML
do {

struct MyObject: Codable {
    var a = 10
    var str = "Hello"
    var array = [1, 2, 3]
}

let obj = MyObject()
let encoder = PropertyListEncoder()
encoder.outputFormat = .xml
let xmlData = try? encoder.encode(obj)
if let xmlData = xmlData,
    let xmlStr = String.init(data: xmlData, encoding: .utf8) {
    print("Xml string is: \(xmlStr)")
}

// 将XML Data转为MyObject对象
let decoder = PropertyListDecoder()
let newObj = try? decoder.decode(MyObject.self, from: xmlData!)
if let obj = newObj {
    print("a = \(obj.a)")
    print("str = \(obj.str)")
    print("array = \(obj.array)")
}

}

目录
相关文章
|
NoSQL 网络协议 数据库
为什么 Lettuce 会带来更长的故障时间
本文详述了阿里云数据库 Tair/Redis 将使用长连接客户端在非预期故障宕机切换场景下的恢复时间从最初的 900s 降到 120s 再到 30s的优化过程,涉及产品优化,开源产品问题修复等诸多方面。
70215 11
为什么 Lettuce 会带来更长的故障时间
|
26天前
|
人工智能 自然语言处理 Shell
🦞 如何在 OpenClaw (Clawdbot/Moltbot) 配置阿里云百炼 API
本教程指导用户在开源AI助手Clawdbot中集成阿里云百炼API,涵盖安装Clawdbot、获取百炼API Key、配置环境变量与模型参数、验证调用等完整流程,支持Qwen3-max thinking (Qwen3-Max-2026-01-23)/Qwen - Plus等主流模型,助力本地化智能自动化。
35446 139
🦞 如何在 OpenClaw (Clawdbot/Moltbot) 配置阿里云百炼 API
|
9天前
|
人工智能 自然语言处理 监控
OpenClaw skills重构量化交易逻辑:部署+AI全自动炒股指南(2026终极版)
2026年,AI Agent领域最震撼的突破来自OpenClaw(原Clawdbot)——这个能自主规划、执行任务的智能体,用50美元启动资金创造了48小时滚雪球至2980美元的奇迹,收益率高达5860%。其核心逻辑堪称教科书级:每10分钟扫描Polymarket近千个预测市场,借助Claude API深度推理,交叉验证NOAA天气数据、体育伤病报告、加密货币链上情绪等多维度信息,捕捉8%以上的定价偏差,再通过凯利准则将单仓位严格控制在总资金6%以内,实现低风险高频套利。
3745 30
|
22天前
|
人工智能 安全 机器人
OpenClaw(原 Clawdbot)钉钉对接保姆级教程 手把手教你打造自己的 AI 助手
OpenClaw(原Clawdbot)是一款开源本地AI助手,支持钉钉、飞书等多平台接入。本教程手把手指导Linux下部署与钉钉机器人对接,涵盖环境配置、模型选择(如Qwen)、权限设置及调试,助你快速打造私有、安全、高权限的专属AI助理。(239字)
7803 22
OpenClaw(原 Clawdbot)钉钉对接保姆级教程 手把手教你打造自己的 AI 助手
|
20天前
|
人工智能 机器人 Linux
OpenClaw(Clawdbot、Moltbot)汉化版部署教程指南(零门槛)
OpenClaw作为2026年GitHub上增长最快的开源项目之一,一周内Stars从7800飙升至12万+,其核心优势在于打破传统聊天机器人的局限,能真正执行读写文件、运行脚本、浏览器自动化等实操任务。但原版全英文界面对中文用户存在上手门槛,汉化版通过覆盖命令行(CLI)与网页控制台(Dashboard)核心模块,解决了语言障碍,同时保持与官方版本的实时同步,确保新功能最快1小时内可用。本文将详细拆解汉化版OpenClaw的搭建流程,涵盖本地安装、Docker部署、服务器远程访问等场景,同时提供环境适配、问题排查与国内应用集成方案,助力中文用户高效搭建专属AI助手。
5333 12
|
4天前
|
存储 人工智能 负载均衡
阿里云OpenClaw多Agent实战宝典:从极速部署到AI团队搭建,一个人=一支高效军团
在AI自动化时代,单一Agent的“全能模式”早已无法满足复杂任务需求——记忆臃肿导致响应迟缓、上下文污染引发逻辑冲突、无关信息加载造成Token浪费,这些痛点让OpenClaw的潜力大打折扣。而多Agent架构的出现,彻底改变了这一现状:通过“单Gateway+多分身”模式,让一个Bot在不同场景下切换独立“大脑”,如同组建一支分工明确的AI团队,实现创意、写作、编码、数据分析等任务的高效协同。
770 21