gpt4 book ai didi

swift 。 unowned 相对于 weak 性能的(绝对)唯一特定优势是什么?

转载 作者:搜寻专家 更新时间:2023-10-30 22:11:14 24 4
gpt4 key购买 nike

在 Swift 中,我们有正常的默认类型

  • 对象不能变成 nil。

我们有弱类型

  • 对象可以变成nil。如果对象变为nil,你的指针自动变为nil,所以你知道对象变为nil

我们有无主打字

  • 对象可以变成nil。如果对象变成 nil,那么你的指针什么也不会发生——如果你试图使用它,你就完蛋了

(因此:推论:唯一一次你可以使用“unowned”的情况是你“绝对知道”该对象永远不会变为 nil。)

现在:

在我看来,下面这句话,

绝对是真的......

我所说的绝对是指,真的,真的,绝对,深入到可能的最深层次的哲学问题真实...

“unowned 和 weak 之间的唯一区别是性能。由于 unowned 没有检查,所以速度更快。绝对没有其他区别。”

因此逻辑推论:

绝对没有理由使用 unowned,除非需要比 weak 更高的性能。”

{除此之外 - 我能想到的唯一其他区别是在 self 记录的意义上。如果我使用 unowned,它会提示我的开发人员了解某些事情;让我们暂时搁置这个问题。)

所以我的问题很直截了当,非常准确,非常具体:上面的粗体句子是“真实的”(在“完全、非常、壮观”的真实意义上是真实的)。

最佳答案

我同意 Yannick 的观点。你的大胆陈述是不正确的。无主引用必须在其生命周期内有效。在 -Ounchecked 程序中,未能保持此前提条件是未定义的行为。我不是说“它崩溃了”。我的意思是它不是一个结构良好的程序;它的作用是不确定的。弱引用不会由于其释放而产生未定义的行为,即使在 -Ounchecked 下也是如此。

使用 unowned 是程序员声明引用在其整个生命周期内都有效。这甚至不是 Type! 断言的东西。 ! 类型只是断言引用在访问时有效。这就是为什么不能在无主对象上测试 x == nil 的原因。它不是可选的。它不是“伪装的可选”(如 Type!)。它必须始终有效。

Unlike a weak reference, however, an unowned reference is used when the other instance has the same lifetime or a longer lifetime. ... An unowned reference is expected to always have a value. —— [The Swift Programming Language]

因此,对于您的“最深层次的哲学”,unowned 包含一个在 weak 中不存在的先决条件。这个前提条件存在于程序之外,必须由程序员而不是编译器来证明,以确保程序的格式正确。

至于是否有理由使用 unowned,如果我们采取绝对立场(如您的问题),那当然是有理由的。在已知前提条件为真的情况下,它是最严格的类型。 weak 是比 unowned 弱的类型;它表示更少的先决条件。好的类型理论鼓励我们尽可能使用最强的(最严格的;最少的合法值)类型,unowned 是比 weak 更强的类型。

在非绝对主义(“实用”)意义上,选择更强类型的结果是更简单的代码。当你使用 weak 时,你每次使用它时都必须不断地重新声明它不是 nil 的前提条件,并处理它所在的情况(可能插入 fatalError 只是用更多的工作 reshape 了 unowned)。使用 unowned 可让您断言此先决条件一次。这会创建更简单、更正确的代码。我从来没有使用 unowned 来提高速度。我一直用它来避免一遍又一遍地回答“但是如果它是零怎么办?”在代码中它绝不能为零。

关于 swift 。 unowned 相对于 weak 性能的(绝对)唯一特定优势是什么?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41830631/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com