c++ - 任何运算符、函数调用和构造函数的通用持续时间计
问题描述
我正在使用模板化的仪表功能(见下文)来测量功能的经过时间。然后我也想将它用于构造函数。
据我所知,没有办法直接将类型作为函数参数传递。所以我想出了这个解决方法,仅将它作为模板参数传递(最小示例):
template <typename T, typename ... P>
auto meter(T t, P ... p) {
auto t1 = high_resolution_clock::now();
t(p...);
auto t2 = high_resolution_clock::now();
auto dif = t2-t1;
return duration_cast<microseconds>(dif);
}
template <typename T, typename ... P>
auto meter(P ... p) {
auto t1 = high_resolution_clock::now();
auto t = T(p...);
auto t2 = high_resolution_clock::now();
auto dif = t2-t1;
return duration_cast<microseconds>(dif);
}
int main() {
auto d = meter(g, 1.0, 20.0); //meter the function call g(1.0, 20.0)
std::cout << "Ellapsed time: " << d.count() << " microseconds\n";
d = meter(complex_obj{2}); //meter () operator of complex_obj, assuming complex_obj{int} is trivial;
std::cout << "Ellapsed time: " << d.count() << " microseconds\n";
d = meter<complex_obj>(); //meter constructor complex_obj();
std::cout << "Ellapsed time: " << d.count() << " microseconds\n";
}
尝试这个让我思考。是否有一种通用/一致的重写方式,适用于任何类型的计算(不仅仅是构造函数,甚至可能是其他运算符,如 (obj1 < obj2)?我注意到,我已经(意外地)支持 ()结构运算符。
对不起,如果这个问题变得广泛,我的主要问题是,如果有一种方法可以统一计量调用的语法,对于函数和构造函数都是如此。
解决方案
您可以将要测量的代码包装在lambda中(C++11 起):
#include <chrono>
#include <iostream>
template<class F>
auto meter(F&& f) {
auto t1 = std::chrono::high_resolution_clock::now();
f();// <-- operator() of the lambda
auto t2 = std::chrono::high_resolution_clock::now();
auto dif = t2-t1;
return std::chrono::duration_cast<std::chrono::microseconds>(dif);
}
void g(double x, double y) {
std::cout << "g(" << x << ", " << y << ")\n";
}
int main() {
double x = 1.0;
auto d = meter([&] {
// This comment is inside the *body* of the lambda.
// Code of the {body} is executed upon `operator()`.
g(x, 20.0);// note that you can use `x` here thanks to the capture-default `[&]`
});
std::cout << "time: " << d.count() << " ms\n";
}
推荐阅读
- visual-studio - 如何将 .Net Core 2.1 项目更改为 .Net Core 2.0 项目
- reactjs - React/Redux - 新道具 - 未调用 componentDidUpdate
- azure - U-SQL 错误 - 更改标识符以使用至少一个小写字母
- macos - 基于 REST 的 Cryptotokenkit 实现
- android - 如何从另一个类 React Native 更改 navigationOptions
- java - 无法压缩位图android studio
- javascript - discord.js-commando if else 循环
- google-app-engine - 将防火墙规则应用于谷歌云中的特定标签不起作用
- c# - 如何根据 WebAPI 中的参数绑定模型
- angular - Angular 4嵌套反应形式手动设置隐藏输入的值