gpt4 book ai didi

c++ - 分析模板元程序编译时间

转载 作者:塔克拉玛干 更新时间:2023-11-03 07:41:13 27 4
gpt4 key购买 nike

我正在开发一个包含大量编译时计算的 C++ 项目。较长的编译时间正在减慢我们的速度。我怎样才能找出我们的模板元程序中最慢的部分,以便我可以优化它们? (当我们的运行时计算速度很慢时,我有很多分析器可供选择,例如 valgrind 的 callgrind 工具。所以我尝试构建一个调试 GCC 并分析它编译我们的代码,但我没有从中学到很多东西那个。)

我使用 GCC 和 Clang,但欢迎提出任何建议。

我在 Boost 的站点上找到了 profile_templates,但它的文档似乎很薄,并且需要 jam/bjam 构建系统。如果您展示如何在非 jam 项目中使用它1,我会投票给您。 https://svn.boost.org/svn/boost/sandbox/tools/profile_templates/似乎计算实例化次数,而计算所用时间将是理想的。

1 我们的项目使用 CMake,并且足够小,可以接受仅用于模板分析的 Jamfile 组合在一起。

最佳答案

我知道这是一个老问题,但我想给出一个更新的答案。

有一组基于 clang 的项目来解决这个特定问题。第一个组件是对 clang 编译器的检测,它生成编译期间发生的所有模板实例化的完整跟踪,包括计时值和可选的内存使用计数。该工具称为 Templight,可在此处访问(目前需要针对修补过的 clang 源代码树进行编译):

https://github.com/mikael-s-persson/templight

第二个组件是一个转换工具,允许您将 templight 跟踪转换为其他格式,例如易于解析的基于文本的格式(yaml、xml、文本等)和更容易可视化的格式,例如 graphviz/graphML,更重要的是可以加载到 KCacheGrind 中的 callgrind 输出,以可视化和检查模板实例化的元调用图及其编译时成本,例如一 block 模板实例化配置文件的屏幕截图创建 boost::container::vector 并使用 std::sort 对其进行排序的代码:

enter image description here

在这里查看:

https://github.com/mikael-s-persson/templight-tools

最后,还有另一个相关项目,它创建了一个交互式 shell 和调试器,能够交互式地在模板实例化图中上下移动:

https://github.com/sabel83/metashell

关于c++ - 分析模板元程序编译时间,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/50065366/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com