次のコードを考えてみましょう: LWS
#include <iostream>
#include <chrono>
#include <cmath>
#include <ctime>
#include <cstdlib>
template <class Counter, class Function, class... Args>
inline double benchmark(const Counter& counter, Function&& f, Args&&... args)
{
const std::chrono::high_resolution_clock::time_point marker
= std::chrono::high_resolution_clock::now();
for (Counter i = Counter(); i < counter; ++i) {
f(args...);
}
return std::chrono::duration_cast<std::chrono::duration<double> >
(std::chrono::high_resolution_clock::now()-marker).count();
}
int main(int argc, char* argv[])
{
srand(time(nullptr));
double y = rand()%10+1;
std::cout<<benchmark(1000000, [](double x){return std::sin(x);}, y)<<"\n";
return 0;
}
関数benchmark
は、関数の実行時間を測定します。問題は、最適化パス中に関数が null ステートメントとして消去されることです。関数を実際に実行させる方法はありますか?
EDIT : 1) 標準 C++ で解決策を探しています (コンパイラ固有の命令はありません) 2)f
可能な限り一般的なままである方がよいでしょう (たとえば、void 戻り値の型)