如何忽略 swift 函数/方法的返回值

这里每天分享一个 iOS 的新知识,快来关注我吧

前言

在 Swift 中写方法的时候,经常会遇到这样的情况:有时需要用到返回值,有时候不需要用到返回值。

举个例子,我们有个方法叫 updateUserInfo,更新用户信息,并返回更新之后的 User:

csharp 复制代码
class User {
    static func updateUserInfo() -> User {
        // 更新用户信息
        // ...
        // 返回最新的用户信息
        return User()
    }
}

当我们用到这个方法时:

swift 复制代码
let newUser = User.updateUserInfo()
print("最新的 User 为:\(newUser)")

但是如果我们仅仅想要更新用户,而不需要关心返回值,这时候系统会给我们一个警告:

一种解决这个警告的方式是使用下划线 _ 来忽略返回值:

ini 复制代码
_ = User.updateUserInfo()

swift 有更好的方式,就是今天要讲的 @discardableResult 关键字。

@discardableResult

@discardableResult 关键字允许我们标记一个带返回值的方法,从而忽略返回值,而不必处理烦人的警告,或者每次都要使用下划线。

只需要在方法的声明前面增加 @discardableResult 关键字即可:

swift 复制代码
class User {
    @discardableResult
    static func updateUserInfo() -> User {
        // 更新用户信息
        // ...
        // 返回最新的用户信息
        return User()
    }
}

当再次使用 User.updateUserInfo()方法,发现警告没有了。

为什么需要这个功能?

这看起来是个很小的功能,但如果不使用的话,整个项目可能充满了警告,消除这个警告之后整个项目就干净多了。

这个关键字的应用非常广泛,我在 swift 常用第三方库 Alamofire 里查了一下,竟然用到了 49 次。

什么情况下需要使用?

总结一下,以下情况应该用 @discardableResult

  1. 当你的函数或方法有返回值,但在某些情况下调用者可能不需要使用这个返回值时。

  2. 当你想要消除因为没有使用函数或方法的返回值而产生的警告时。

然而,也不是所有情况都应该用这个关键字,在以下情况下最好不要不使用@discardableResult

  1. 当函数或方法的返回值对于调用者来说总是重要且必须被处理时。例如,如果一个函数执行一些操作并返回一个错误(如果存在),那么你希望调用者应该处理这个错误。

  2. 有些时候如果忽略函数或方法的返回值可能导致错误或不正确的行为,则不应使用 @discardableResult

这里每天分享一个 iOS 的新知识,快来关注我吧

本文同步自微信公众号 "iOS新知",每天准时分享一个新知识,这里只是同步,想要及时学到就来关注我吧!

相关推荐
bryceZh42 分钟前
iOS26适配-UISplitViewController配置分栏和分屏
ios·ui kit
songgeb1 小时前
NumberFormatter 货币格式化属性详解
ios·swift
for_ever_love__4 小时前
UI学习:数据驱动ce l l
学习·ui·ios·objective-c
KillerNoBlood5 小时前
2026移动端跨平台开发面经总结
android·算法·flutter·ios·移动开发·鸿蒙·kmp
人月神话-Lee6 小时前
【图像处理】颜色科学与灰度化——人眼看到的和数字记录的不一样
图像处理·人工智能·计算机视觉·ios·swift
号码认证服务6 小时前
给用户打电话,怎么在对方手机显示为“XX证券”?号码认证办理步骤
android·运维·服务器·ios·智能手机·iphone·webview
MonkeyKing6 小时前
iOS 启动优化实战:pre-main耗时、二进制重排与动态库裁剪全解析
ios
MonkeyKing6 小时前
iOS 卡顿优化实战:离屏渲染、混合图层与圆角优化全解析
ios
库奇噜啦呼9 小时前
【iOS】源码学习-消息流程分析
学习·ios·cocoa
2501_915918419 小时前
iOS性能数据监控:从概念到工具实践,让应用运行更流畅
android·macos·ios·小程序·uni-app·cocoa·iphone