关于“幽灵架构”的补充说明4:协议的应用场景与局限性

简介: 再次解释一下协议的意义:定义某个功能模块的最小粒度,因为Swift是单继承,而无论是值类型还是引用类型都可以遵守多个协议,因此协议是比父类的粒度还要小的功能模块。

再次解释一下协议的意义:定义某个功能模块的最小粒度,因为Swift是单继承,而无论是值类型还是引用类型都可以遵守多个协议,因此协议是比父类的粒度还要小的功能模块。协议的功能定义一定要具体并且严格,someObject:Protocol where …中where子句的匹配条件只能针对someObject的类型或者遵守的其他协议,以及Protocol中的associatedType的约束,也就是说不能根据someObject中的成员判断是否遵守该协议。举例如下:
Swift标准库中的很多基础类型都遵守了Equatable协议,这个协议要求用户定义一个==方法,这表明虽然每个类型判断是否相等的标准不同,但是在任何情况下两个遵守了Equatable协议的相同类型都可以判等,这是协议为我们所做的工作。考虑我们常用的数组,Array中也可以使用==运算,但是Array并没有遵守Equatable协议,这是因为调用Array实例的==方法的时候编译器会做限制,只有Array中所保存的元素遵守了Equatable协议的时候,Array才能进行判等,所以Array不是在任何条件下都能进行判等的,不符合Equatable协议的功能描述。这种情况下我们需要直接定义一个方法:

func ==<T: Equatable>(lhs: [T], rhs: [T]) -> Bool { 
     //对比las和rhs中的元素是否相等
}

方法的好处是你可以引用任意的泛型作为占位符来描述功能呢,比如这里的T,这样就可以规范两个参数必须是相同类型的数组,并且元素遵守Equatable。当Array中的元素不遵守Equatable时,在编译期调用==就会收到编译器错误。
而在使用协议的时候,someObject:Protocol where …这里的where只能对协议中声明的associatedType进行约束,而不能引入向T这样额外的占位符来描述约束。

目录
相关文章
|
6月前
|
消息中间件 监控 大数据
Kafka消息队列架构与应用场景探讨:面试经验与必备知识点解析
【4月更文挑战第9天】本文详尽探讨了Kafka的消息队列架构,包括Broker、Producer、Consumer、Topic和Partition等核心概念,以及消息生产和消费流程。此外,还介绍了Kafka在微服务、实时数据处理、数据管道和数据仓库等场景的应用。针对面试,文章解析了Kafka与传统消息队列的区别、实际项目挑战及解决方案,并展望了Kafka的未来发展趋势。附带Java Producer和Consumer的代码示例,帮助读者巩固技术理解,为面试做好准备。
609 0
|
1月前
|
消息中间件 NoSQL Kafka
大数据-52 Kafka 基础概念和基本架构 核心API介绍 应用场景等
大数据-52 Kafka 基础概念和基本架构 核心API介绍 应用场景等
61 5
|
6月前
|
资源调度 前端开发 JavaScript
第十章(应用场景篇) Single-SPA微前端架构深度解析与实践教程
第十章(应用场景篇) Single-SPA微前端架构深度解析与实践教程
222 0
|
6月前
|
缓存 自然语言处理 前端开发
第一章 引言-HTTP协议基础概念和前后端分离架构请求交互概述
第一章 引言-HTTP协议基础概念和前后端分离架构请求交互概述
144 0
用户态协议栈05—架构优化
用户态协议栈05—架构优化
|
3月前
|
安全 网络安全 数据安全/隐私保护
|
5月前
|
存储 SQL BI
深入解析实时数仓Doris:介绍、架构剖析、应用场景与数据划分细节
深入解析实时数仓Doris:介绍、架构剖析、应用场景与数据划分细节
|
5月前
|
传感器 边缘计算 监控
边缘云作为一种分布式云计算架构,正在为多个行业和应用场景带来革命性的变化
边缘云应用于智能城市、工业物联网、零售、农业、AI、5G优化、制造、物流、医疗、交通和家居等领域,实现低延迟的数据处理、实时分析与优化。例如,智能交通利用边缘计算优化信号灯,减少拥堵;工业场景中,设备监控与预测性维护提升效率;在医疗中,实时监测患者数据支持远程诊断。此外,边缘云还助力零售业的个性化推荐、农业的精准作业和云游戏的高性能体验。
|
5月前
|
自然语言处理 监控 搜索推荐
《百炼成金-大金融模型新篇章》––12.应用场景与技术架构选型(1)
百炼必定成金,新质生产力会催生新质劳动力,谨以此文抛砖引玉,希望与业内的各位朋友一同探讨如何积极拥抱并运用大模型技术,以应对和驾驭不断变化的市场环境,实现科技金融持续稳定的提质增效和创新发展,携手开启金融大模型未来新篇章。
107 1
|
5月前
|
数据采集 人工智能 自然语言处理
《百炼成金-大金融模型新篇章》––12.应用场景与技术架构选型(2)
百炼必定成金,新质生产力会催生新质劳动力,谨以此文抛砖引玉,希望与业内的各位朋友一同探讨如何积极拥抱并运用大模型技术,以应对和驾驭不断变化的市场环境,实现科技金融持续稳定的提质增效和创新发展,携手开启金融大模型未来新篇章。