Objective-C引入了零运行时成本直接法

最近Objective-C引入了零运行时成本直接法这个话题,相信很多小伙伴都是非常有兴趣了解的吧,一段好的故事可以给读者带来很多值得深思的新东西,甚至还可以在一定程度上让读者的视野在瞬间扩大,那么既然现在大家都想要知道此类的信息,今日小编将给带来关于Objective-C引入了零运行时成本直接法的资讯!

Objective-C引入了零运行时成本直接法

自S wift于2014年推出以来,Objective-C只知道一些小的变化,主要是为了验证其与Swift的互操作性。然而,Objective-C并不是一种边缘语言,它最近增加了对“直接”方法的支持,这些方法看起来像一般 的类方法,但表现得更像C函数。

虽然Swift作为构建iOS应用程序的首选语言吸引了最大的兴趣,但Objective-C仍然在开辟人员中很受欢迎。事实上,如果真的是斯威夫特在2016年首次超过TIOBE指数中的Objective-C,那么截至2019年11月,Objective-C在TIOBE指数中已经攀升至第12位,斯威夫特排名第10位。有趣的是,这两种语言已经多次交换了他们的TIOBE排名。同样,Stack Overflow语言排名根据流行的问答论坛上提出的问题数量来衡量语言的采纳程度,这突出了人们对Objective-C的兴趣下降。Stack Overflow数字可以通过Swift收集进入iOS开辟领域的大多数新开辟人员,以及过去几年对Objective-C的修改次数减少来具体解释。

尽管如此,Objective-C的新功能还是让很多人感到有些意外。简而言之,一个直接方法同意 定义一些特别类型的属性,这些属性不附带Objective-C元数据,其getter和setter方法几乎表现为直C函数。这个新特性:

行时方法解析相关的一些开销..这使得使用这个新功能来优化一些关键路径变得有趣,就像PSPD FKit知名度的iOS开辟人员彼得·斯坦伯格在Twitter上所说的那样。无论如何,并不是所有的开销都被删除,因为LLVM中的直接方法实现力求使其与标准的Object-C方法兼容。特殊是,隐式self和_cmd参数都被保留,并进行了一些检查,以确保两者在调用方法时都是正常的。

开辟人员如何使用直接方法有一些限制。首先,直接方法只能在内部、私有API上使用,不能被框架公开。此外,重载的方法不能是直接的,也不能是直接的方法,也不能重载直接的方法;实现不能重新声明它与直接的接口的非直接方法;所需的协议方法不能是直接的;最后,您不能发送不限定的id直接方法。

除了优化关键路径的可能性外,对这一新的客观-C特征的反应并不完全是积极的一面。iOS开辟人员TannerB评论说,直接方法伤害了许多基本的目标C特性,如KVC、KVO、方法闪烁等。第一天应用程序开辟商BJ Homer表示,他担心苹果可能会使用直接方法来使调整更难完成:

objc_direct_member注释似乎有效地实现了Objc的真正私有方法。静态发送,不可覆盖。我可以看到苹果在内部大量使用这种方法来幸免人们调用私有方法。

这一担忧在某种程度上被著名的iOS开辟者和图书作者尼克·洛克伍德所忽视,因为直接方法只能是私人的:

这应该有助于减轻人们的担忧,即它将从根本上改变Objective-C的性质,方法是阻挠像KVO这样的滑动和破坏功能。

苹果高级软件工程师皮埃尔·哈布齐特也证实了这一点。

最后,虽然直接方法已经合并为LLVM,但不太可能在明年WWDC之前在X code中提供这些方法。

(0)
上一篇 2022年7月10日
下一篇 2022年7月10日

相关推荐