Combine 框架,从0到1 —— 4.在 Combine 中使用计时器
本文首发于 Ficow Shen's Blog,原文地址: Combine 框架,从0到1 —— 4.在 Combine 中使用计时器。
内容概览
- 前言
- 使用计时器执行周期性的工作
- 将计时器转换为计时器发布者(
Timer.TimerPublisher
) - 总结
前言
计时器是苹果开发者常用的功能。如果你的应用使用 Foundation
框架中的计时器 Timer
来周期性地执行某些操作,你可以用 Combine
简化这些代码。
现在,让我们来学习如何使用 Combine
处理计时器,并将已有的计时器处理代码迁移到 Combine
。
使用计时器执行周期性的工作
对于 iOS
开发人员而言,以下代码一定非常眼熟:
var timer: Timer?
override func viewDidLoad() {
super.viewDidLoad()
timer = Timer.scheduledTimer(withTimeInterval: 1, repeats: true) { _ in
self.myDispatchQueue.async() {
self.myDataModel.lastUpdated = Date()
}
}
}
以上代码使用 scheduledTimer(withTimeInterval:repeats:block:)
来实现每秒钟在 myDispatchQueue
中更新 self.myDataModel.lastUpdated
的功能。
将计时器转换为计时器发布者(Timer.TimerPublisher
)
要将以上代码迁移到 Combine
,只需将 Timer
(scheduledTimer(withTimeInterval:repeats:block:)
的返回值) 替换为 Timer.TimerPublisher
。调用 Timer. publish(every:tolerance:on:in:options:)
方法即可创建一个发布者。
每次底层的计时器(Timer
)触发时,发布者都会发出一个新的日期(Date
)实例,该日期代表计时器触发的瞬间。然后,你可以将 Combine
操作符应用到这个日期实例上,最终将这个发布者和一个订阅者(如:sink(receiveValue:)
或 assign(to:on:)
)连接。
由于
Timer.TimerPublisher
遵从ConnectablePublisher
协议,因此在您显式地连接之前,它不会产生任何元素。为此,可以通过手动调用connect()
或使用autoconnect()
运算符在订阅者连接时自动连接来实现。关于ConnectablePublisher
的用法,可以参考 这篇文章。
下一个示例将展示如何使用 Timer.TimerPublisher
替换上一个示例。它使用 Combine
的操作符来完成上一个示例中的闭包中的操作:
var cancellable: Cancellable?
override func viewDidLoad() {
super.viewDidLoad()
cancellable = Timer.publish(every: 1, on: .main, in: .default)
.autoconnect()
.receive(on: myDispatchQueue)
.assign(to: \.lastUpdated, on: myDataModel)
}
在这个例子中,Combine
操作符替换了上一个示例的闭包中的所有行为:
receive(on:options:)
操作符确保了后续操作在指定的调度队列中执行,它替代了前面用到的async()
调用;assign(to:on:)
操作符通过键路径来更新数据模型的lastUpdated
属性;
使用 Combine
来简化你的代码时,你会发现 Timer.TimerPublisher
会产生新的 Date
实例作为其输出类型。而第一个示例的闭包是将 Timer
本身作为其参数,因此它必须手动创建新的 Date
实例。
总结
使用 Combine
来简化你的计时器代码时,你会发现:
- 代码易读性明显提升;
- 线程切换变得更简单;
- 数据模型的更新可以通过键路径(
key path
)来简化;
朋友,行动起来吧!把现有项目中的旧代码重构成使用 Combine
的代码~
本文内容来源:
Replacing Foundation Timers with Timer Publishers
Combine 框架,从0到1 —— 4.在 Combine 中使用计时器的更多相关文章
- Combine 框架,从0到1 —— 1.核心概念
本文首发于 Ficow Shen's Blog,原文地址: Combine 框架,从0到1 -- 1.核心概念. 内容概览 前言 核心概念 RxSwift Combine 总结 参考内容 ...
- Combine 框架,从0到1 —— 2.通过 ConnectablePublisher 控制何时发布
本文首发于 Ficow Shen's Blog,原文地址: Combine 框架,从0到1 -- 2.通过 ConnectablePublisher 控制何时发布. 内容概览 前言 使用 ma ...
- Combine 框架,从0到1 —— 3.使用 Subscriber 控制发布速度
本文首发于 Ficow Shen's Blog,原文地址: Combine 框架,从0到1 -- 3.使用 Subscriber 控制发布速度. 内容概览 前言 在发布者生产元素时消耗它们 使 ...
- Combine 框架,从0到1 —— 4.在 Combine 中使用通知
本文首发于 Ficow Shen's Blog,原文地址: Combine 框架,从0到1 -- 4.在 Combine 中使用通知. 内容概览 前言 让通知处理代码使用 Combine 总结 ...
- Combine 框架,从0到1 —— 4.在 Combine 中使用 KVO
本文首发于 Ficow Shen's Blog,原文地址: Combine 框架,从0到1 -- 4.在 Combine 中使用 KVO. 内容概览 前言 用 KVO 监控改动 将 KVO 代 ...
- Combine 框架,从0到1 —— 4.在 Combine 中执行异步代码
本文首发于 Ficow Shen's Blog,原文地址: Combine 框架,从0到1 -- 4.在 Combine 中执行异步代码. 内容概览 前言 用 Future 取代回调闭包 用输出类型( ...
- Combine 框架,从0到1 —— 5.Combine 提供的发布者(Publishers)
本文首发于 Ficow Shen's Blog,原文地址: Combine 框架,从0到1 -- 5.Combine 提供的发布者(Publishers). 内容概览 前言 Just Future D ...
- Combine 框架,从0到1 —— 5.Combine 中的 Subjects
本文首发于 Ficow Shen's Blog,原文地址: Combine 框架,从0到1 -- 5.Combine 中的 Subjects. 内容概览 前言 PassthroughSubject C ...
- Combine 框架,从0到1 —— 5.Combine 常用操作符
本文首发于 Ficow Shen's Blog,原文地址: Combine 框架,从0到1 -- 5.Combine 常用操作符. 内容概览 前言 print breakpoint handleEve ...
随机推荐
- C#LeetCode刷题之#605-种花问题( Can Place Flowers)
问题 该文章的最新版本已迁移至个人博客[比特飞],单击链接 https://www.byteflying.com/archives/3724 访问. 假设你有一个很长的花坛,一部分地块种植了花,另一部 ...
- Vue 过滤器 Filter传递参数
给日期类型过滤器设置不同格式 dayjs是一款轻量级的日期操作库 https://day.js.org/en import Vue from 'vue' import dayjs from 'dayj ...
- 解决"$ is not defined" 亲自体验
引入jquery <script src="http://libs.baidu.com/jquery/1.9.0/jquery.js"></script>
- 牛X!看完阿里P8架构师推荐的spring三剑客,成功涨薪5k
一直以来,Spring都被Java程序员视为杀手级别的应用,是为简化Java EE应用程序的开发为目标而创建的.Spring可以做很多事情,它为企业级开发提供给了丰富的功能,但是这些功能的底层都依赖于 ...
- 前端 go.js 流程图基于vue开发项目案例
一.流程图效果 最近一段时间在研究go.js,它是一款前端开发画流程图的一个插件,也是一个难点,要说为什么是难点,首先,它是依赖画布canvas知识开发.其次,要依赖于内部API开发需求,开发项目需求 ...
- CODING DevOps 微服务项目实战系列最后一课,周四开讲!
随着软件工程越来越复杂化,如何在 Kubernetes 集群进行灰度发布成为了生产部署的"必修课",而如何实现安全可控.自动化的灰度发布也成为了持续部署重点关注的问题.CODING ...
- JavaScript学习系列博客_27_JavaScript 遍历数组
遍历数组 - 遍历数组就是将数组中元素都获取到 - 一般情况我们都是使用for循环来遍历数组: - 使用forEach()方法来遍历数组(不兼容IE8) forEach()方法需要一个回调函数(由我们 ...
- Python开发的入门教程(一)-数据类型、变量
介绍 Python第一门课程,是Python开发的入门教程,将介绍Python语言的特点和适用范围,Python基本的数据类型,条件判断和循环,函数,以及Python特有的切片和列表生成式. Pyth ...
- 如何加速github下载速度
第一步 魔法 第二步 git config --global http.proxy http://127.0.0.1:1080 git config --global https.proxy http ...
- Docker 镜像构建之 docker commit
我们可以通过公共仓库拉取镜像使用,但是,有些时候公共仓库拉取的镜像并不符合我们的需求.尽管已经从繁琐的部署工作中解放出来,但是实际开发时,我们可能希望镜像包含整个项目的完整环境,在其他机器上拉取打包完 ...