ch7.6numalg.cc

来自「C++ source code for book-C++ and Object 」· CC 代码 · 共 49 行

CC
49
字号
// comparision in efficiency for passing function object, 
// function pointer, and truely inline code

#include <iostream>
#include <vector>
#include <numeric>
#include <iostream>
#include <ctime>

template<class T> struct SumFO {            // passing function object 
  T operator()(const T& a, const T& b) const { return a + b; }
};

double SumFcn(double a, double b) { return a + b; }  

//template<class T> T SumFcn(T a, T b) { return a + b; }  

int main() {
  using namespace std;

  int n = 1000;
  int m = 50000;
  double* ai = new double [n]; 
  for (int i = 0; i < n; i++) ai[i] = i - 500;
  double d =  0;

  time_t tm1 = time(0);                   // time_t is defined in <time.h> 

  for (int i = 0; i < m; i++)             // do it 100 times
    d = accumulate(ai, ai + n, 0.0);      // summation by default
  cout << " d = " << d << "\n";

  time_t tm2 = time(0);                   // measur the current time
  cout << "time in default sum = " << tm2 -tm1 << " seconds" << "\n";

  for (int i = 0; i < m; i++)             // do it 100 times
    d = accumulate(ai, ai + n, 0.0, SumFcn); // passing a function
  cout << " d = " << d << "\n";

  time_t tm3 = time(0);                   // measur the current time
  cout << "time in passing function = " << tm3 -tm2 << " seconds" << "\n";

  for (int i = 0; i < m; i++)             // do it 100 times
    d = accumulate(ai, ai + n, 0.0, SumFO<double>()); // passing a fcn object
  cout << " d = " << d << "\n";
  time_t tm4 = time(0);                   // measur the current time
  cout << "time in passing fcn object = " << tm4 -tm3 << " seconds" << "\n";
}

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?