首页 >后端开发 >C++ >为什么编译器不优化冗余原子写入?

为什么编译器不优化冗余原子写入?

Susan Sarandon
Susan Sarandon原创
2024-12-23 04:21:11339浏览

Why Don't Compilers Optimize Redundant Atomic Writes?

为什么原子写入在编译器中没有被优化

问题:为什么编译器不合并冗余的原子写入单个原子具有相同的值变量?

解释:

C 11/14 标准允许将原子变量的连续存储折叠或合并到单个存储中。在某些情况下,即使商店具有不同的值,也可以执行此优化。然而,由于多种因素,编译器目前不会执行此优化。

避免优化的原因:

  • 违反最小惊喜原则: 程序员期望每个原子存储将单独执行,这可能会影响可观察的
  • 进度条问题:将多个商店优化为一个可能会导致进度条突然显示最终值,而不是逐渐更新。
  • 实施困难: 安全地执行这些优化需要编译器中的复杂代码,这可能会引入
  • 实用性有限:优化在特定情况下很有用,但也可能导致其他情况下出现意外行为。

解决方案和未来的考虑因素:

目前,没有办法显式地控制这种优化C 11/14 标准。然而,扩展 std::atomic API 的讨论正在进行中,以使程序员能够更好地控制此类优化。这可以使编译器在有用时执行优化而不违反排序规则。

替代方法:

使用易失性原子变量可以防止编译器优化原子存储。然而,这并不是一个万无一失的解决方案,在某些情况下仍可能导致意外行为。

以上是为什么编译器不优化冗余原子写入?的详细内容。更多信息请关注PHP中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn