当前位置: 首页 > news >正文

Swift 基于Codable协议使用

Codable协议 继承自 Decodable & Encodable

//
// Test1.swift
// TestDemo
//
// Created by admin on 2024/7/9.
//

import Foundationstruct Player{var name:Stringvar highScore:Int = 0var history:[Int] = []var address:Address?var birthday:Date?init(name: String) {self.name = name}}extension Player{mutating func updateScore(_ newScore:Int){history.append(newScore)if(highScore < newScore){highScore = newScore}}
}

//Codable 继承自 Decodable & Encodable
/*

Codable 是 Swift 中用于简化对象序列化和反序列化的协议组合。它由 Encodable 和 Decodable 组成,分别用于将对象编码为外部表示(如 JSON)和从外部表示解码对象。通过实现 Codable,我们可以轻松地将自定义类型与 JSON 等格式进行转换。

*/

extension Player:Codable{/*如果 JSON 中的键与结构体中的属性名称不一致,可以使用 CodingKeys 枚举来定义自定义的键映射*/enum CodingKeys:String,CodingKey{case namecase highScorecase addresscase birthdaycase history = "history1"}
}

/*
Codable 同样适用于嵌套类型
*/

struct Address:Codable{var street:Stringvar citty:Stringvar zipCode:String
}
func test111(){var player = Player(name: "John")player.address = Address(street: "宝田一路", citty: "深圳", zipCode: "2212")player.birthday = Date(timeIntervalSince1970: 25 * 365 * 24 * 60 * 60)player.updateScore(121)player.updateScore(134)/*默认情况下,JSONEncoder 和 JSONDecoder 对日期的处理方式可能不符合需求,可以自定义日期格式*/let formatter = DateFormatter()formatter.dateFormat = "yyyy-MM-dd"let encoder = JSONEncoder()encoder.dateEncodingStrategy = .formatted(formatter)let jsonData = try? encoder.encode(player)guard let jsonData = jsonData else{print("json data is nil")return}let jsonStr = String(data: jsonData, encoding: .utf8)guard let jsonStr = jsonStr else{print("json 数据编码失败")return}print("player 转json 字符串 : " + jsonStr)let decoder = JSONDecoder()decoder.dateDecodingStrategy = .formatted(formatter)guard let jsonDataDe = jsonStr.data(using: .utf8) else {print("json DataDe is null")return}//解码异常处理和打印var user :Player?do {user = try decoder.decode(Player.self, from: jsonDataDe)} catch let DecodingError.dataCorrupted(context) {print(context)} catch let DecodingError.keyNotFound(key, context) {print("Key '\(key)' not found:", context.debugDescription)print("codingPath:", context.codingPath)} catch let DecodingError.valueNotFound(value, context) {print("Value '\(value)' not found:", context.debugDescription)print("codingPath:", context.codingPath)} catch let DecodingError.typeMismatch(type, context)  {print("Type '\(type)' mismatch:", context.debugDescription)print("codingPath:", context.codingPath)} catch {print("Error: ", error)}guard let user = user else{print("user is null")return}print("name:" + user.name + ",score:" + "\(user.highScore)")}
http://www.lryc.cn/news/399414.html

相关文章:

  • conda激活的虚拟环境的python版本不对应
  • 深度学习概览
  • 什么是白盒测试中的静态测试?其包含哪些过程和方法?
  • 搭建一个高并发的Web商品推荐系统,如何涉及软件架构?
  • 今日科技圈最新时事新闻(2024年7月12日
  • jenkins系列-09.jpom构建java docker harbor
  • 构造+贪心,CF 432E,Square Tiling
  • 【Linux】任务管理
  • 计算机网络——常见问题汇总
  • Linux的世界 -- 初次接触和一些常见的基本指令
  • [AI 大模型] Meta LLaMA-2
  • Python3.6.6 OpenCV 将视频中人物标记或者打马赛克或加图片并保存为不同格式
  • Readiris PDF Corporate / Business v23 解锁版安装教程 (PDF管理软件)
  • .NET MAUI开源架构_2.什么是 .NET MAUI?
  • 认知偏差知识手册
  • SpringBoot后端代码基本逻辑
  • Python学生信息管理系统的设计与实现
  • 最优雅的PHP框架 Laravel
  • log4j2的日志框架(详细,springboot和异步日志的实现)
  • taocms 3.0.1 本地文件泄露漏洞(CVE-2021-44983)
  • SpringBoot实战:处理全局异常
  • pdf只要前几页,pdf中只要前几页怎么处理
  • 实变函数精解【4】
  • 【BUG】Python3|COPY 指令合并 ts 文件为 mp4 文件时长不对(含三种可执行源代码和解决方法)
  • AI克隆声音,基于函数计算部署GPT-Sovits语音生成模型
  • DP讨论——建造者模式
  • 【JavaScript】解决 JavaScript 语言报错:Uncaught SyntaxError: Unexpected token
  • oracle数据库的plsql免安装版安装
  • stm32使用通用定时器生成pwm
  • 老物件线上3D回忆展拓宽了艺术作品的展示空间和时间-深圳华锐视点