- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我有一个辅助函数可以执行一些非常昂贵的操作。
我正在尝试分析算法的主要部分,但这个辅助函数在其中被调用了很多次。因此,测量的时间考虑了辅助功能的时间。
为了解决这个问题,我决定设置和恢复时间,使辅助功能看起来是瞬时的。我定义了以下宏:
#define TIME_SAVE struct timeval _time_tv; gettimeofday(&_time_tv,NULL);
#define TIME_RESTORE settimeofday(&_time_tv,NULL);
. . .并将它们用作辅助函数的第一行和最后一行。但是,出于某种原因,辅助函数的开销仍然包括在内!
所以,我知道这是一个有点困惑的解决方案,所以我继续前进,但我仍然很好奇为什么这个想法没有奏效。谁能解释一下为什么?
最佳答案
如果您坚持以这种方式进行分析,请不要设置系统时钟。如果您有权这样做,这将破坏各种各样的事情。基本上你应该忘记你曾经听说过 settimeofday
。您要做的是在要从测量中排除的函数之前和之后调用 gettimeofday
,然后计算差值。然后,您可以从总时间中排除花在该功能上的时间。
话虽如此,这整个“分析”方法存在很大缺陷,因为 gettimeofday
可能 (1) 与您要测量的内容相比花费大量时间,并且 (2 ) 可能涉及到内核空间的转换,这会对程序的缓存一致性造成严重损害。第二个问题是最有问题的,即在试图观察您的程序的性能特征时您实际上改变了它们。
你真正应该做的是忘掉这种分析(gettimeofday
甚至 gcc 的 -pg
/gmon 分析),而是使用 oprofile
或 perf
或类似的东西。这些现代分析技术的工作原理是定期对指令指针和堆栈信息进行统计采样;您的程序自己的代码根本没有被修改,因此它的行为尽可能接近没有运行分析器的行为。
关于c - gettimeofday/settimeofday 使函数看起来不花时间,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10370128/
我用 redis 后端运行 celery。 我想在 centos 6.2 上运行 celery 花作为守护进程。 我知道花是 Tornado 应用程序,所以我应该使用一个进程来运行 Tornado 应
我在一台服务器上有几个项目,它们使用具有不同 BROKER_URL 的 celery 包。Flower 允许一个 BORKER_URL 作为命令选项: celery flower --broker=a
我正在使用芹菜和花卉。当我访问Flower中的“任务”标签时,我可以看到我的任务正在注册,甚至可以在“状态”列中看到“成功”标签以及所有内容。 但是,在“监视器”选项卡上,所有图形(“成功任务”,“失
我正在尝试创建一个有 5 个叶子的 css 花 - 没有任何有希望的尝试。我正在尝试创建什么:有 5 片叶子的 CSS 花,每片叶子可以有三种不同的状态(小、中、大)。我找到了 http://ross
如果我有一个变体,像这样: using my_variant = boost::variant; 有没有一种简单的方法可以将变体可以包含的类型提取到 Boost.Hana 元组中,以便满足以下条件:
调用 Flower API's /api/task/apply/* 只是挂起而没有返回结果,即使任务已根据 Web UI 处理并成功。 重现错误: # hangs even though task s
我有一个模板函数,默认情况下没有定义,但它由某些类型特化: template auto foo(bar &, const T &) -> void; template <> auto foo(bar
就目前情况而言,这个问题不太适合我们的问答形式。我们希望答案得到事实、引用资料或专业知识的支持,但这个问题可能会引发辩论、争论、民意调查或扩展讨论。如果您觉得这个问题可以改进并可能重新开放,visit
我是一名优秀的程序员,十分优秀!