在 Swift 中,参数标签(argument label),用于在调用函数时提高代码的可读性。

大家好,我的开源项目PakePlus可以将网页/Vue/React项目打包为桌面/手机应用并且小于5M只需几分钟,官网地址:pakeplus.com

1. 函数签名分析

swift 复制代码
func session(_ session: ARSession, didUpdate frame: ARFrame)
  • func session:方法名

  • _ session: ARSession:第一个参数,_ 表示调用时省略参数标签

  • didUpdate frame: ARFrame:第二个参数,didUpdate 是参数标签,frame 是参数名

2. 调用时的区别

scss 复制代码
// 调用第一个参数(省略标签)
session(someARSession, didUpdate: someARFrame)

// 如果没有 didUpdate 标签,调用会是:
session(someARSession, someARFrame) // 可读性差

3. didUpdate 的含义

  • 字面意思:"已经更新了"

  • 语义作用:表明这个参数代表的是"被更新的帧"

  • 代码可读性:让调用代码读起来像自然语言

4. 类似的例子

swift 复制代码
// 其他常见的参数标签
func tableView(_ tableView: UITableView, didSelectRowAt indexPath: IndexPath)
func textField(_ textField: UITextField, shouldChangeCharactersIn range: NSRange)

总结

didUpdate 是一个参数标签,它的作用是:

  • 提高代码可读性

  • 明确参数的含义(表示这是一个被更新的帧)

  • 遵循 Swift 的 API 设计惯例

在方法内部,你使用参数名 frame 来访问这个值,而在调用时使用 didUpdate 标签来使代码更加清晰

Swift 使用参数标签的设计是为了解决多个问题,而不仅仅是技术必要性。

主要原因:

1. 提高代码可读性

scss 复制代码
// 有标签 - 读起来像自然语言
session(someSession, didUpdate: currentFrame)

// 无标签 - 含义不明确
session(someSession, currentFrame) // 这个 currentFrame 是什么?

2. 区分多个参数

当方法有多个参数时,标签尤为重要:

less 复制代码
// 清晰明确
func calculateArea(of shape: String, width: Double, height: Double)

calculateArea(of: "rectangle", width: 10, height: 5)

// 对比:没有标签会很混乱
calculateArea("rectangle", 10, 5) // 10 和 5 分别代表什么?

3. 遵循 Swift API 设计准则

Swift 鼓励编写"自文档化"的代码:

less 复制代码
// Swift 风格 - 可读性强
x.addSubview(y)
button.setTitle("Hello", for: .normal)

// 对比其他语言 - 可读性较差
x.add(y)
button.setTitle("Hello", .normal)

4. 方法重载时的清晰度

swift 复制代码
func move(to position: CGPoint)
func move(by delta: CGVector)
func move(towards direction: Direction)

// 调用时非常清晰
move(to: targetPosition)
move(by: movementVector) 
move(towards: .north)

在你的具体例子中:

swift 复制代码
// 当前设计:
func session(_ session: ARSession, didUpdate frame: ARFrame)

// 如果去掉标签:
func session(_ session: ARSession, frame: ARFrame)

// 调用时:
session(someSession, frame: someFrame) // 含义不明确 - 是要设置帧?还是帧更新了?

技术上的等价性

实际上,你可以这样写:

swift 复制代码
// 方式1:使用不同标签和参数名
func session(_ session: ARSession, didUpdate frame: ARFrame)

// 方式2:标签和参数名相同
func session(_ session: ARSession, frame: ARFrame)

// 方式3:省略标签(不推荐)
func session(_ session: ARSession, _ frame: ARFrame)

大家好,我是1024小神,技术群 / 私活群 / 股票群 或 交朋友 都可以私信我。 如果你觉得本文有用,一键三连 (点赞、评论、关注),就是对我最大的支持~

相关推荐
joker学java2 小时前
el表达式jstl和我们的js都是什么时候使用
前端
晴殇i2 小时前
前端极速性能优化:从加载到渲染的全链路实战指南
前端·javascript
joker学java2 小时前
el,js,jstl什么时候进行混用
前端
AAA阿giao2 小时前
JavaScript 深拷贝全解析:从栈与堆内存机制到安全对象复制实践
前端·javascript·json
Keya2 小时前
鸿蒙Next系统手机使用Charles配置证书并抓包教程
前端·harmonyos
Vhen2 小时前
Vue2项目部署后更新版本提示
前端
搞个锤子哟2 小时前
vue移动端开发长按对话复制功能
前端
AAA阿giao2 小时前
深入理解 JavaScript 的 Array.prototype.map() 方法及其经典陷阱:从原理到面试实战
前端·javascript·面试
excel3 小时前
HBuilderX 配置 adb.exe + 模拟器端口一体化完整指南
前端