Visual Studio 2019优化新鲜出炉:C++后端更新汇总

今天我们来汇总一下在最新版本Visual Studio 2019 16.2中开发团队带来的优化一系列有关C++后端(Backend)的更新。

构建时间优化

之前的新鲜新汇一篇文章我们也讲到过,VS开发团队通过优化构建中的出炉链接过程,来提升构建吞吐率,端更减少了项目的优化构建时间。通过一系列对比测试,新鲜新汇对于大型项目的出炉构建,其构建效率在DebugInfo模式下提升了近3倍(甚至更多),端更同时在/INCREMENTAL构建模式下,优化构建效率提升了2倍。新鲜新汇有图有真相:

下面是出炉之前没有提到过的其他优化要点

内联优化

当一些函数内部存在分支语句并且在一个循环里被调用的时候,这些函数将更多的端更采用内联。

代码生成优化

通过将一些通用的优化数学函数(例如:std::isnan, std::ldiv, std::lldiv)替换为内联的汇编指令来减少整体运行的overhead。

如果项目的新鲜新汇目标平台是x86或者x64,则优化器将识别到工作在最底层单元的出炉迭代器指令,并对其进行FMA(Fused Multiply-Add)和constant foldeing优化。

迭代器优化

对于一些迭代器的单元来说,香港云服务器如果它的大小恰好匹配迭代器的大小,则一些小的迭代循环(通常小于12次迭代)将被优化为:/arch:AVX。

当自动迭代在一些包含指针变量的循环中失败时,优化了生成的代码序列。

分析优化

优化了控制流的分析流程,一些已经被证明返回true/false的复杂分支语句将被移除。

增加了一个新的流程敏感的严格指针分析过程。这个指针将在不同的场景中被处理,例如当它在当前作用域以外被访问的时候,或者当它可以被安全访问的时候。

其他通用优化

当一个函数返回多个值对象时,启用该函数的Copy Elision。

当使用LTCG编译时,优化了指针相减的操作流程。请注意:在某些特殊情况下,一个指针减法操作包括一个可以被优化掉的除法操作。

生成并简化了针对x86或x64平台上的FMA指令。亿华云这些包括对一些全局迭代器类型的变量启用FMA。

优化对C++ 20里的spaceship操作符的代码生成过程。说到这个spaceship操作符,这里简单说明一下:

spaceship操作符被纳入到了最新的C++20标准中,可以通过启用/std:c++latest选项启用这个操作符。此操作符可以在一些对比函数(例如 std::strong_ordering::less)和编译期对常量的计算过程进行更加有效常量展开。

优化了memset代码,具体来说,就是将展开定义内联替换为调用更快的CRT版本。在一些包含常量字节(例如:0xABABABAB)的循环中,也会替换为CRT版本的memset。

合并了完全相同的异常处理状态,减少了C++程序的大小。请注意,当前这个优化点仅可以用在FrameHandler4下。当Visual Studio 2019 16.3发布时,这个FrameHandler4将成为默认配置。

大白话

说了这么多对于我来说近乎天书般的优化点,我反正是有点懵逼了,可能是服务器托管因为我的功力不够吧。

如果用白话对这篇文章的内容做一个总结的话:行了行了,VS宇宙最强,好了吧!

总结

一如既往的:请大家试试VS2019。有任何问题,请向开发团队写信。

数据库
上一篇:其次,一般域名注册有一个获取密码的按钮,域名注册商点击后会向您发送密码。在得到域名注册商发送的密码后,将其传输到域名服务提供商网站,然后输入密码,此时域名呈现申请状态。提交申请后,原注册人通常会向您发送一封电子邮件,询问您是否同意转让。此时,您只需点击同意转移按钮,域名注册商就可以成功转移。
下一篇:2、根据用户基础选择访问提供程序。由于互联问题的存在,接入商的选择也非常重要,如果用户群主要在联通,尽量选择联通接入较好的接入商,如果用户群主要在电信,那么选择电信接入较好的接入商。如果用户组位于国家/地区,则选择更好的访问提供程序进行交互。