SwiftUI中结合使用Timer和onReceive

SwiftUI提供了一种现代化的方式来构建用户界面,其中包括对时间驱动的事件的响应。在许多应用中,可能需要根据时间间隔执行某些操作,例如更新界面或触发事件。SwiftUI通过结合使用TimeronReceive 来实现这一功能,使得处理时间相关的任务变得简单而直观。

Timer 的基本使用

Swift 中,Timer 是一个用于创建重复或非重复计时器的类,它可以在特定的时间间隔触发。在 SwiftUI 中,通常会使用 Timer.publish 方法来创建一个发布者,该发布者可以在给定的时间间隔内发送当前日期和时间。

例如,如果你想每秒更新一次数据,可以这样设置 Timer:

let timer = Timer.publish(every: 1, on: .main, in: .common).autoconnect()

这行代码做了以下几件事:
every: 1 设置 Timer 每秒触发一次。
on: .main 确保 Timer 在主线程上运行,这对于 UI 更新非常重要。
in: .commonTimer 添加到当前运行循环的通用模式中。
autoconnect() 启动 Timer,使其开始发送事件。

使用 onReceive 监听 Timer

SwiftUI 视图中,可以使用 onReceive 修饰符来监听来自 Timer 的事件。onReceive 需要一个发布者和一个当接收到数据时将执行的闭包。
onReceiveTimer 结合使用的示例代码如下:

struct TimerDemo: View {@State private var currentTime = Date()let timer = Timer.publish(every: 1, on: .main, in: .common).autoconnect()var body: some View {Text("Current time: \(currentTime)").padding().font(.headline).onReceive(timer) { value incurrentTime = value}}
}

控制 Timer

在实际应用中,可能需要在某些条件下启动或停止 Timer。由于 autoconnect() 会立即启动 Timer,我们可以通过将其连接存储为 @State@StateObject 并在需要时取消它来管理 Timer
例如,添加一个按钮来控制 Timer 的启动和停止:

  @State private var currentTime = Date()@State private var timer: Cancellable?var body: some View {VStack {Text("Current time: \(currentTime)").padding().font(.headline)Button(timer == nil ? "Start Timer" : "Stop Timer") {if timer == nil {timer = Timer.publish(every: 1, on: .main, in: .common).autoconnect().sink {currentTime = $0}} else {timer?.cancel()timer = nil}}}}

这里创建了一个Cancellable类型的timer属性,Cancellable 是一个协议,属于 Combine 框架。Combine是 Apple 在 2019 年推出的一个用于处理异步事件和数据流的框架。Cancellable 协议是 Combine 中非常核心的一个部分,它用于管理异步操作和数据流的生命周期。

当你创建一个订阅到某个发布者(Publisher)的订阅者(Subscriber)时,这个订阅操作会返回一个遵循 Cancellable 协议的实例。这个实例代表了订阅本身,你可以通过调用它的 cancel() 方法来停止接收更多的更新,从而有效地管理资源和避免潜在的内存泄漏。

在创建timer的时候使用 sink() 方法来处理时间更新,这将返回一个遵循 Cancellable 协议的实例。当想要停止timer的时候,我们调用 cancel() 方法来取消订阅,这有助于清理资源。

除了手动控制timer,有时候我们也需要在界面显示的时候开启timer,在离开界面的时候停止timer,如下:

  @State private var currentTime = Date()@State private var timer: Cancellable?var body: some View {VStack {Text("Current time: \(currentTime)").padding().font(.headline).onAppear {timer = Timer.publish(every: 1, on: .main, in: .common).autoconnect().sink {currentTime = $0}}.onDisappear {timer?.cancel()timer = nil}}}

timer 设置为 nil 在某些情况下是有益的,特别是当你使用 sink() 方法时。sink() 会返回一个 Cancellable 对象,这个对象可以用来停止计时器。当你调用 cancel() 方法后,计时器会停止发送事件。将 timer 设置为 nil 可以帮助确保计时器被适当地释放,尤其是在它不再需要时,这有助于避免内存泄漏或其他资源管理问题。

每次需要 Timer 时重新创建一个新的实例是一种安全的做法,尤其是在使用 autoconnect() 的情况下。这样做的好处是你可以确保 Timer 的状态始终是干净的,不会受到之前使用状态的影响。此外,这也避免了对同一个 Timer 实例重复调用 autoconnect(),可能导致不可预见的行为。

最后,希望能够帮助到有需要的朋友,如果觉得有帮助,还望点个赞,添加个关注,笔者也会不断地努力,写出更多更好用的文章。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/diannao/26144.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【免杀】C2远控-Loader加载器-动态API调用

目录 创建后门程序站在杀毒程序立场上对后门进行分析例&#xff1a;动态调用VirtualProtect函数 作用:绕过杀毒对导入表的检测定性 创建后门程序 VS新建项目 回调函数加载Loader #include <Windows.h>unsigned char shellcode[] "";void CallBack() {void* p…

FlashBrowser

本例&#xff1a;windows10 下载FlashBrowser 解决flash失效问题&#xff0c;更换浏览器 https://www.flash.cn/ 下载FlashBrowser浏览器

Redis的缓存击穿、缓存穿透和缓存雪崩是什么?怎么预防?

Redis的缓存击穿、缓存穿透和缓存雪崩是什么&#xff1f;怎么预防&#xff1f; 前言缓存击穿定义解决思路实现加锁设置过期时间Lua脚本刷新锁 缓存穿透定义实现 缓存雪崩定义解决思路 总结 前言 最近在CSDN上看到了一篇博客&#xff0c;Redis缓存击穿、雪崩、穿透&#xff01;…

深入理解Vue3.js响应式系统基础逻辑

如果您觉得这篇文章有帮助的话&#xff01;给个点赞和评论支持下吧&#xff0c;感谢~ 作者&#xff1a;前端小王hs 阿里云社区博客专家/清华大学出版社签约作者/csdn百万访问前端博主/B站千粉前端up主 此篇文章是博主于2022年学习《Vue.js设计与实现》时的笔记整理而来 书籍&a…

15-字符串处理的常用函数——查找字符串,求字符串长度,分割字符串,查找指定字符,比较字符串,连接字符串

15-字符串处理的常用函数——查找字符串&#xff0c;求字符串长度&#xff0c;分割字符串&#xff0c;查找指定字符&#xff0c;比较字符串&#xff0c;连接字符串 文章目录 15-字符串处理的常用函数——查找字符串&#xff0c;求字符串长度&#xff0c;分割字符串&#xff0c;…

C++:SLT容器-->stack

C:SLT容器--&#xff1e;stack 1. stack容器2. stack 常用接口 1. stack容器 先进后出&#xff0c;后进先出不允许有遍历行为可以判断容器是否为空可以返回元素的个数 2. stack 常用接口 构造函数 stack<T> stk; // stack采用模板类实现&#xff0c;stack对象的默认构造形…

第1期JAVA社招面试经验月报

面经哥专注互联网社招面试经验分享&#xff0c;关注我&#xff0c;每日推送精选面经&#xff0c;面试前&#xff0c;先找面经哥&#xff5c;面经哥整理了上月30篇面试经历&#xff0c;选取了较为热点高频的面试题供大家参考 基础知识类‍‍‍‍‍ 1、说下双亲委派原则以及类加…

1992-2012年美国西海岸的海面高度异常数据集

Gridded Altimeter Fields with Enhanced Coastal Coverage 具有增强海岸覆盖范围的网格化测高场 简介 具有增强的海岸覆盖范围的网格化高度计场数据产品包含美国西海岸的海面高度异常&#xff08;SSHA 或 SLA&#xff09;以及北纬 35.25 度-48.5 度和东经 227.75 度-248.5 …

Vue3 渲染函数 API(五)

h() h 函数用于创建并返回一个虚拟节点&#xff08;VNode&#xff09; h( tag, // HTML 标签名、组件对象或异步组件函数 data, // 一个包含组件的props/attrs/domProps/on 等的对象 children // 子虚拟节点 (VNodes)&#xff0c;由 h()构建而成&#xff0c; // 也可以使用字符…

解析final原理

原理 public class TestFinal {final int a 20; //final保证不能读到两个值} 字节码&#xff1a; 写屏障&#xff1a; 之前的指令不会重排序到后面去&#xff08;有序性&#xff09; 之前的修改、赋值操作之后会同步到主内存中去&#xff08;可见性&#xff09; 0: aload…

大学生如何学习JavaScript?

学习 JavaScript 对于大学生来说是一个宝贵的技能&#xff0c;因为它是现代网页开发的核心语言之一。以下是一些详细的步骤&#xff0c;帮助大学生学习 JavaScript&#xff1a; 1. 了解 Web 开发基础 学习 HTML 和 CSS&#xff0c;这是网页开发的基石。 2. 学习 JavaScript …

什么是transformer?

整个 transformer 的重点在 QKV 结构上。 以前的 CNN 试图通过卷积来表达不同位置数值之间的关系&#xff0c;学习卷积值也就是学习矩阵里的数值之间的特征&#xff0c;所以适合用在图像里面。因为图像就是一个个的像素点形成的矩阵。 RNN 试图通过加入反馈机制来理解一串数值…

Python酷库之旅-开启库房之门

目录 一、库的定义 二、库的组成 三、库的分类 四、如何学好Python库&#xff1f; 五、注意事项 六、推荐阅读 1、Python筑基之旅 2、Python函数之旅 3、Python算法之旅 4、Python魔法之旅 5、 博客个人主页 一、库的定义 在Python中&#xff0c;库(Library)是一个封…

探索智慧机场运营中心解决方案的价值与应用

随着全球航空业的不断发展&#xff0c;机场运营中心的作用日益凸显。智慧机场运营中心解决方案以其高效的管理和智能化的运营模式&#xff0c;成为优化机场运营、提升服务水平的重要工具。本文将深入探讨智慧机场运营中心解决方案的价值与应用&#xff0c;揭示其在机场管理中的…

机器学习常见知识点 2:决策树

文章目录 决策树算法1、决策树树状图2、选择最优决策条件3、决策树算法过程→白话决策树原理决策树构建的基本步骤常见的决策树算法决策树的优缺点 【五分钟机器学习】可视化的决策过程&#xff1a;决策树 Decision Tree 关键词记忆&#xff1a; 纯度、选择最优特征分裂、熵、基…

Ubuntu下ClickHouse安装

用 root 身份运行, 注意在install那一步, 不要设置密码 # 使用官方安装源&#xff0c;跳过签名验证。&#xff08;因为使用 gpg 完全通过代理获取签名的问题至今没有解决。&#xff09; echo deb [trustedyes] https://packages.clickhouse.com/deb stable main > /etc/apt…

电脑上的瑞士军刀

一、简介 1、一款专为 Windows 操作系统设计的桌面管理工具&#xff0c;它具备保存和恢复桌面图标位置的功能&#xff0c;使用户能够在各种情况下&#xff0c;如分辨率变动、系统更新或其他原因导致的图标位置混乱后&#xff0c;快速恢复到熟悉的工作环境。它还拥有诸多实用功能…

【Pyqt6 学习笔记】实现串口调试助手,并将接收到数据模拟键盘输出

文章目录 代码示例main.pyscreen_shot_module.pyqrcmd.pyuntitled.pyuntitled.ui 本文内容是 【Pyqt6 学习笔记】DIY一个二维码解析生成小工具的延申&#xff0c;在原来的基础上实现了串口调试助手功能&#xff0c;并利用 pywinauto的 keyboard模块将接收到数据模拟键盘输出…

【递归+二叉树思想+搜索】 Alice and the Cake题解

Alice and the Cake题解 AC记录&#xff1a;记录-洛谷 题面翻译&#xff08;大概就是题目大意&#xff09; 执行恰好 n − 1 n-1 n−1 次操作&#xff0c;每次操作可以选择当前所有蛋糕中满足其重量 w ⩾ 2 w\geqslant 2 w⩾2 的一块&#xff0c;然后将其分为质量分别为 …

手机连接ESP8266的WIFI,进入内置网页,输入要显示的内容,在OLED显示屏上显示文本

连线 OLEDESP8266含义GNDGND地线VCC3V电源SCLD1时钟线SDAD2通信数据线 只支持英文信息的显示和数字。 #include <ESP8266WiFi.h> #include <ESP8266WebServer.h> #include <Wire.h> #include <Adafruit_GFX.h> #include <Adafruit_SSD1306.h>#d…