首页
学习
活动
专区
圈层
工具
发布

Profiling
EN

Stack Overflow用户
提问于 2018-04-19 18:13:34
回答 1查看 141关注 0票数 1

我有一个大型的基于探地雷达的项目,需要超过30分钟来编译。

在分析了构建过程之后,我注意到许多明显的低效率(对gprbuild的多次调用而不是聚合,过度使用替代文件而不是配置,等等)。我想知道是否有什么方法可以“剖析”构建过程,看看什么花了这么长时间。

特别是,当单个文件发生更改且其中存在错误时,重新编译大约需要5分钟。理论上,应该很快意识到必须重新编译该文件(这是唯一需要重新编译的文件)并启动编译过程,从而快速发现错误。

从冗长的输出来看,仅仅解析用于定义构建的大量gpr文件需要相当长的时间,但是我想知道它大部分时间都花在哪里了。

因此,我的问题是:是否有可能对gprbuild所做的构建进行分析?如果是这样的话,是怎么做的?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2018-04-19 19:10:19

从低到高的复杂性:

  • gprbuild报告更多关于其如何处理标志-vh的详细信息。
  • 通过gprbuild运行strace
  • 使用所需的标志重新构建gprbuild,以便使用gprof对其进行分析(但请注意,gprof并不总是说实话)。
票数 5
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/49927612

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档