BT

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

GCC 8.1支持C++2a的部分特性

| 作者 Sergio De Simone 关注 12 他的粉丝 ,译者 谢丽 关注 9 他的粉丝 发布于 2018年5月17日. 估计阅读时间: 3 分钟 | GMTC大前端的下一站,PWA、Web框架、Node等最新最热的大前端话题邀你一起共同探讨。

亲爱的读者:我们最近添加了一些个人消息定制功能,您只需选择感兴趣的技术主题,即可获取重要资讯的邮件和网页通知

看新闻很累?看技术新闻更累?试试下载InfoQ手机客户端,每天上下班路上听新闻,有趣还有料!

GCC 8.1是GNU编译器集的最新主版本,该版本对即将到来的C++2a标准的某些部分提供了实验性支持。此外,GCC 8.1改进了性能分析驱动的优化,并把Go支持提升到了1.10.1版本。

虽然对于即将到来的C++草案,有关工作尚处于起步阶段,但GCC C++前台提供了两个新标识-std=c++2a-std=gnu++2a,以便启用已经预先批准的部分C++新特性,其中包括指定初始化针对位域的默认成员初始化器针对预处理程序逗号省略的VA_OPTlambda捕获[=, this]简化的隐式lambda捕获等等。要了解GCC 8中的全部C++2a特性,请查阅C++状态页面

此外,C++的前台输出现在改进了诊断信息,包括改进了位置和位置范围,并提供了若干新的故障排除线索。例如,在以下情况下,编译器现在可以提供一个线索,如在定义之前使用宏,试图访问类或结构的私有字段,当旧式的转换可以用static_castconst_castreinterpret_cast替代。

GCC 8.1显著改善了性能分析驱动的优化。这些优化使用对被检测代码的性能分析结果决定优化哪一部分代码。例如,GCC现在默认会把面向x86的函数分成热区和冷区。热函数的优化力度更大,GCC会把它们放在同一个区域里,增强局部性。同样,GCC现在能够从一个有效运行的程序中检测不执行的代码,比如,它在某一时刻触发了未定义的行为。

谈到优化,该版本还新增了循环优化,如-floop-unroll-and-jam执行外部循环展开和内部循环融合,-floop-interchange执行嵌套循环中的循环互换,增强数据局部性。一些已有的优化器也经过了改进,包括-floop-nest-optimize-ftree-loop-distribution。所有优化器都是使用-O3标识默认启用的。

前面已经提到,Go支持经过了改进,这得益于Go 1.10.1的完整实现,这是Go最新的官方版本。此外,其垃圾收集器现在是完全并发的了。

最后需要注意的一点是, GCC 8.1还引入了Armv8.4-A架构支持,可以通过-march=armv8.4-a选项启用,可伸缩向量扩展(SVE)支持现在是作为Armv8.2-A架构及更高版本的可选扩展。

GCC 8.1还包含许多更有趣的变化,要了解全部细节,请查看官方的发布说明

查看英文原文New GCC 8.1 Supports Some Features of C++2a

评价本文

专业度
风格

您好,朋友!

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

获得来自InfoQ的更多体验。

告诉我们您的想法

允许的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通知我

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

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

讨论

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


找回密码....

Follow

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

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

Like

内容自由定制

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

Notifications

获取更新

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

BT