Swift 结构化并发之全局 Actor 趣谈

2024-03-20 18:52

本文主要是介绍Swift 结构化并发之全局 Actor 趣谈,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

在这里插入图片描述

概览

在 Swift 结构化并发构成的体系中,一个称为“演员”(Actor)的成员扮演了非常重要的角色,它被用来隔离和同步执行中的数据。

在这里插入图片描述

除了普通 Actor 以外,还有一个全局“演员”(Global Actor)的概念,它是做什么的?又有什么与众不同的长处呢?

在本篇博文中,您将学到如下内容:

  • 概览
  • 1. MainActor:“我是主角!”
  • 2. 何为全局 Actor?
  • 3. “开始你的表演!”
  • 总结

掌握 Swift 结构化并发是迈向现代化并行开发模型的必由之路,而 Actor 以及 Global Actor 又是其中不可或缺的重要元素!

那还等什么呢?小伙伴们,Let‘s playing!!!😉


1. MainActor:“我是主角!”

我相信即使是 Apple 开发中头发浓密的初学者们也肯定都知道:所有和界面相关的操作一定要在主线程(Main Thread)中完成。

对于 Swift 结构化并发中的 Actor 来说,这一点也不能例外。

所以,一个所谓的“绝对主角”(Main Actor)踏着七彩祥云“从天而降”来帮助我们排忧解难。在 UIKit 中,所有和界面相关的类,以及它们对应的方法和属性,默认都包容在 MainActor 之中:

在这里插入图片描述
在这里插入图片描述

在 SwiftUI 中,视图的 body 属性也很“识趣”的与 MainActor 成了好朋友:

在这里插入图片描述

在 Swift 结构化并发模型中, 使用 MainActor 可以确保我们的任务都毫无悬念的将会在主线程中运行。

在某些非 MainActor 的运行上下文中,我们也可以非常方便的将其切换到主线程上去:

Task {// 非 MainActor 运行上下文await MainActor.run {// MainActor 运行上下文}
}

或者,我们还可以用闭包的修饰语法糖来让编译器明白我们要在 MainActor 中运行的“坚定决心”:

Task {await withTaskGroup(of: Void.self) {group ingroup.addTask {@MainActor intry? await Task.sleep(for: .seconds(1.0))print(Thread.current)// 在主线程中了,加油妆点界面吧!}await group.waitForAll()}
}

如上所述,MainActor 就是一个在主线程上下文中运行的 Actor,更确切的说:它是运行在主线程中的一个全局(Global)Actor!

2. 何为全局 Actor?

所谓全局 Actor 是一种全局唯一的 Actor 类型,它用于隔离程序任何位置中的各种声明代码。

在这里插入图片描述

说到全局 Actor,我们很自然的就想到普通的 Actor。做个不太恰当的比喻:如果说普通的 Actor 创建出一个个数不胜数的隔绝小岛,那么全局 Actor 形成的则是一片壮丽浩瀚的隔绝大陆!

上面我们讨论过&#x

这篇关于Swift 结构化并发之全局 Actor 趣谈的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/830415

相关文章

Java JUC并发集合详解之线程安全容器完全攻略

《JavaJUC并发集合详解之线程安全容器完全攻略》Java通过java.util.concurrent(JUC)包提供了一整套线程安全的并发容器,它们不仅是简单的同步包装,更是基于精妙并发算法构建... 目录一、为什么需要JUC并发集合?二、核心并发集合分类与详解三、选型指南:如何选择合适的并发容器?在多

Java 结构化并发Structured Concurrency实践举例

《Java结构化并发StructuredConcurrency实践举例》Java21结构化并发通过作用域和任务句柄统一管理并发生命周期,解决线程泄漏与任务追踪问题,提升代码安全性和可观测性,其核心... 目录一、结构化并发的核心概念与设计目标二、结构化并发的核心组件(一)作用域(Scopes)(二)任务句柄

SpringBoot全局域名替换的实现

《SpringBoot全局域名替换的实现》本文主要介绍了SpringBoot全局域名替换的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一... 目录 项目结构⚙️ 配置文件application.yml️ 配置类AppProperties.Ja

Web服务器-Nginx-高并发问题

《Web服务器-Nginx-高并发问题》Nginx通过事件驱动、I/O多路复用和异步非阻塞技术高效处理高并发,结合动静分离和限流策略,提升性能与稳定性... 目录前言一、架构1. 原生多进程架构2. 事件驱动模型3. IO多路复用4. 异步非阻塞 I/O5. Nginx高并发配置实战二、动静分离1. 职责2

Spring Security 前后端分离场景下的会话并发管理

《SpringSecurity前后端分离场景下的会话并发管理》本文介绍了在前后端分离架构下实现SpringSecurity会话并发管理的问题,传统Web开发中只需简单配置sessionManage... 目录背景分析传统 web 开发中的 sessionManagement 入口ConcurrentSess

MySQL中处理数据的并发一致性的实现示例

《MySQL中处理数据的并发一致性的实现示例》在MySQL中处理数据的并发一致性是确保多个用户或应用程序同时访问和修改数据库时,不会导致数据冲突、数据丢失或数据不一致,MySQL通过事务和锁机制来管理... 目录一、事务(Transactions)1. 事务控制语句二、锁(Locks)1. 锁类型2. 锁粒

深入解析Java NIO在高并发场景下的性能优化实践指南

《深入解析JavaNIO在高并发场景下的性能优化实践指南》随着互联网业务不断演进,对高并发、低延时网络服务的需求日益增长,本文将深入解析JavaNIO在高并发场景下的性能优化方法,希望对大家有所帮助... 目录简介一、技术背景与应用场景二、核心原理深入分析2.1 Selector多路复用2.2 Buffer

go动态限制并发数量的实现示例

《go动态限制并发数量的实现示例》本文主要介绍了Go并发控制方法,通过带缓冲通道和第三方库实现并发数量限制,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面... 目录带有缓冲大小的通道使用第三方库其他控制并发的方法因为go从语言层面支持并发,所以面试百分百会问到

Go语言并发之通知退出机制的实现

《Go语言并发之通知退出机制的实现》本文主要介绍了Go语言并发之通知退出机制的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧... 目录1、通知退出机制1.1 进程/main函数退出1.2 通过channel退出1.3 通过cont

java如何实现高并发场景下三级缓存的数据一致性

《java如何实现高并发场景下三级缓存的数据一致性》这篇文章主要为大家详细介绍了java如何实现高并发场景下三级缓存的数据一致性,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 下面代码是一个使用Java和Redisson实现的三级缓存服务,主要功能包括:1.缓存结构:本地缓存:使