衡量执行效率以比较两个解决方案?

Posted

技术标签:

【中文标题】衡量执行效率以比较两个解决方案?【英文标题】:Measure execution efficiency for compairing two solutions? 【发布时间】:2021-08-22 15:09:10 【问题描述】:

我想衡量同一问题的两种解决方案的效率。

我不需要在计算中加入任何环境“噪音”,只是想知道以下哪些解决方案在完美世界中表现更好,即:哪些需要更多步骤来执行?

string a;
int b;
string c;

//SOLUTION A
c = a;
c = std::move(c) + ',' + std:to_string(b);

//SOLUTION B
c = a;
c.append(",").append(std::to_string(b));

我真的没有任何经验来测量这种小规模的执行时间,所以我可能在丛林中迷路了,如果是这种情况,很抱歉。

【问题讨论】:

【参考方案1】:

一种方法是对两种解决方案进行基准测试,例如与QuickBench。在图表中: 您可以看到第二种解决方案更快。但是,代码的执行时间也可能取决于您尝试连接的字符串的大小和数量,因此请考虑到这一点。我还建议对整个解决方案进行基准测试(无论您尝试实现什么),而不仅仅是一行代码(这里:append vs operator+)。

您也可以尝试使用不同的编译器和不同的优化级别。

【讨论】:

同意所有建议。我在这里的目的是只知道哪个单线更好,而您的答案涵盖了这 100%。谢谢!

以上是关于衡量执行效率以比较两个解决方案?的主要内容,如果未能解决你的问题,请参考以下文章

都说程序执行的效率跟算法有关,究竟啥是计算机的算法呢?怎么理解的?怎么使用?

所谓 A/B test

pyspark 数据框比较以根据关键字段查找列差异

如何将理论效率与实践示例进行比较[关闭]

时间复杂度

python-opencv性能衡量和提升技术