以下代码段产生了一个非常奇怪的输出,我不知道为什么。
对于我的其他测试程序,它应该是非常原始的基准。无论执行cmd行参数两次时传递了什么可执行文件,都要计算时钟周期,然后计算均值和标准差(很好,尚未完全实现,但是您知道了)。
#include <algorithm>
#include <cmath>
#include <ctime>
#include <iostream>
#include <numeric>
#include <vector>
class SRS{
public:
SRS(double p1):mean(p1), srs(0.0){std::cout << this->mean << std::endl;} //DEBUG
double operator()(unsigned p1){
this->srs += std::pow(this->mean - (double)p1, 2.0);
std::cout << p1 << " " << this->srs << std::endl; //DEBUG
}
double getSrs(){
return this->srs;
}
private:
double mean;
double srs;
};
int main(int argc, char* argv[]){
unsigned nCyc;
if(argc<3){nCyc=1000;}else{nCyc=std::stoi(argv[2]);}
std::vector<clock_t> c{};
for(unsigned u = 0; u<nCyc; u+=1){
clock_t t = clock();
system(argv[1]); //this is stupid and dangerous
t = clock() - t;
c.push_back(t);
}
clock_t clkSum = std::accumulate(c.begin(), c.end(), 0);
double clkMean = (double)clkSum / (double)nCyc;
SRS srs(clkMean);
std::for_each(c.begin(), c.end(), srs);
std::cout << "The program ran for " << clkMean << " +/- " << srs.getSrs() << " clock cycles" << std::endl;
return 0;
}
让我感到困惑的是,srs.getSrs()总是返回c'tor分配给SRS::srs的任何值(此处为0.0)。
在创建流的输出之后评估std::for_each还是在执行后std::for_each将功能对象恢复为以前的状态?
最佳答案
std::for_each
的谓词参数是一个值,这意味着该算法使用作为参数传递的函子的副本。如果要检查其状态,可以使用返回给您的副本:
SRS ret = std::for_each(c.begin(), c.end(), srs);
std::cout << "The program ran for " << clkMean
<< " +/- " << ret.getSrs() << " clock cycles" << std::endl;