C&C++   发布时间:2022-04-03  发布网站:大佬教程  code.js-code.com
大佬教程收集整理的这篇文章主要介绍了c – 为什么没有clang / llvm优化这个?大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。
用clang 3.9编译这段代码时: @H_450_5@ @H_450_5@
constexpr bool is_small(long long v) {
  return v < 0x4000000000000000;
}
int foo();
int f(int a) {
  if (is_small(a)) return a;
  else return foo();
}
@H_450_5@它产生相当于int f(int a)的汇编{return a;因为它确定is_small(a)将永远为真,因为a是一个int,它(在我的平台上)总是小于0x4000000000000000.

@H_450_5@当我将is_small更改为:

@H_450_5@
constexpr bool is_small(long long v) {
  return v >= -0x4000000000000000;
}
@H_450_5@正如预期的那样,完全相同.

@H_450_5@但是,当我更改is_small以检查两个条件时:

@H_450_5@
constexpr bool is_small(long long v) {
  return v < 0x4000000000000000 && v >= -0x4000000000000000;
}
@H_450_5@clang没有优化if和返回foo()部分.

@H_450_5@(这是关于Godbolt的上述片段,可以玩:https://godbolt.org/g/fnoE9A)

@H_450_5@为什么会这样?它清楚地得出结论,个别条件总是正确的,为什么这不延伸到两者的逻辑结合?

解决方法

没有充分的理由,这是LLVM缺少的优化.提交 https://llvm.org/bugs/show_bug.cgi?id=30794以确保它得到修复. @H_450_5@ @H_450_5@基本上LLVM首先在内联它并优化f()中的使用之前优化is_small.在优化is_small时,它正在转变比较v< 0x4000000000000000&& v> = -0x4000000000000000到v 0x4000000000000000> -1.内联后,优化器无法识别这种新形式,允许在f()中不断折叠代码.

大佬总结

以上是大佬教程为你收集整理的c – 为什么没有clang / llvm优化这个?全部内容,希望文章能够帮你解决c – 为什么没有clang / llvm优化这个?所遇到的程序开发问题。

如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。