BT

如何利用碎片时间提升技术认知与能力? 点击获取答案

Swift 4 ABI稳定性的征途

| 作者 Sergio De Simone 关注 12 他的粉丝 ,译者 Alina 关注 0 他的粉丝 发布于 2017年2月10日. 估计阅读时间: 3 分钟 | Google、Facebook、Pinterest、阿里、腾讯 等顶尖技术团队的上百个可供参考的架构实例!

最近发布在swift-evolution邮件杂志上的《Swift ABI稳定性宣言》旨在汇编公开宣称Swift ABI稳定前所需解决的所有问题。

《Swift ABI稳定性宣言》的作者——苹果公司工程师Michael Ilseman写道,ABI稳定性的目标包含以下两个主要部分:

  • 定义一个模块文件,这个模块文件包含了Swift编译器关于把公共框架的API与在运行时加载的可执行代码捆绑在一起的描述的标准化表示。
  • 定义一系列影响低级别细节的约定,例如如何调用函数,如何在内存中表示数据和元数据等。

Ilseman特别指出需要致力于以下六个方面:

  • 数据布局,主要是定义如何在内存中布置struct和class实例。
  • 类型元数据,要求有特定的内存布局或API查询。
  • name mangling,主要是定义编译器如何分别标识外部符号,例如类型和函数。
  • 函数调用约定,主要是定义如何将参数传入/传出函数,以及该保留哪些寄存器等。
  • Swift runtime,主要是提供动态转换、引用计数、反射等的基本机制,属于ABI的一部分。
  • 标准库,它的API是ABI的一部分,应用程序和库都会调用它。

ABI稳定性是Swift 4计划的优先级最高的功能之一,对第三方框架开发人员至关重要。正如InfoQ报道所指出,Swift 3因为无法定义锁定ABI之前需要定义的一些方面,所以没有实现ABI的稳定性。在最近的Accidental TechS播客采访中,前苹果工程师兼Swift创始人Chris Lattner表示,ABI稳定性对于应用程序开发人员来说并不重要,但“对苹果公司来说非常重要”,并且它是公司内部采用Swift的关键因素:

要真正地在苹果公司全面采用Swift,Swift团队必须实现一些特定目标。ABI稳定性是阻止框架开发人员采用Swift的首要因素。这是一件非常重要的事情,也是ABI稳定性总是排在很高优先等级的原因之一。

实际上,目前仍然不完全清楚Swift 4 ABI是否能被宣称为具有稳定性。Lattner说,这可能受两个因素的影响,它们是ABI稳定性包含的工作量以及它可能不是Swift社区最重要的事情。

如果他们什么时候决定专注于Swift 4中其他比ABI稳定性更重要的方面,我也不会感到惊讶。

Lattner指出了一些Swift社区中排在更高优先级别的问题:比如使编译器更具可靠性,更准确的错误提示,加快编译速度,以及使Swift更适用于大型项目。

查看英文原文The Road to Swift 4 ABI Stability


感谢王纯超对本文的审校。

给InfoQ中文站投稿或者参与内容翻译工作,请邮件至editors@cn.infoq.com。也欢迎大家通过新浪微博(@InfoQ@丁晓昀),微信(微信号:InfoQChina)关注我们。

评价本文

专业度
风格

您好,朋友!

您需要 注册一个InfoQ账号 或者 才能进行评论。在您完成注册后还需要进行一些设置。

获得来自InfoQ的更多体验。

告诉我们您的想法

允许的HTML标签: a,b,br,blockquote,i,li,pre,u,ul,p

当有人回复此评论时请E-mail通知我

swift这个名称真是差劲 by styshoo book

在it行业,已经有了swift对象存储,又来个swift语言,给我们搜索带来了很多不便。命名想搜索队形存储的东西,跳出来的全都是语言;反之也是如此。

允许的HTML标签: a,b,br,blockquote,i,li,pre,u,ul,p

当有人回复此评论时请E-mail通知我

允许的HTML标签: a,b,br,blockquote,i,li,pre,u,ul,p

当有人回复此评论时请E-mail通知我

1 讨论

登陆InfoQ,与你最关心的话题互动。


找回密码....

Follow

关注你最喜爱的话题和作者

快速浏览网站内你所感兴趣话题的精选内容。

Like

内容自由定制

选择想要阅读的主题和喜爱的作者定制自己的新闻源。

Notifications

获取更新

设置通知机制以获取内容更新对您而言是否重要

BT