新しい chrono ライブラリ (C++11) を見て、それを使用しようとしていました。以下の 2 つのプログラムを作成しました。
ベクトル.cpp
#include <iostream>
#include <vector>
#include <chrono>
int main()
{
std::vector<double> vector(1000000, 0.);
auto start = std::chrono::high_resolution_clock::now();
for(int i(0); i < vector.size(); i++)
{
vector[i] += 1.;
}
auto end = std::chrono::high_resolution_clock::now();
std::cout << "Elapsed time: " << std::chrono::duration_cast<std::chrono::milliseconds>(end-start).count() << " milliseconds" << std::endl;
return 0;
}
配列.cpp
#include <iostream>
#include <array>
#include <algorithm>
#include <chrono>
int main()
{
std::array<double, 1000000> array;
std::fill(array.begin(), array.end(), 0.);
auto start = std::chrono::high_resolution_clock::now();
for(int i(0); i < array.size(); i++)
{
array[i] += 1.;
}
auto end = std::chrono::high_resolution_clock::now();
std::cout << "Elapsed time: " << std::chrono::duration_cast<std::chrono::milliseconds>(end-start).count() << " milliseconds" << std::endl;
return 0;
}
配列プログラムで9ミリ秒、ベクトルプログラムで12ミリ秒を取得しました。std::vector は、std::array よりも約 33% 遅いようです。私はそれを正しくやっていますか?この違いはなぜですか?
Ps: GCC 4.7、Mac OS X 10.7 を使用しています。
g++-mp-4.7 -std=c++11 vector.cpp -o vector
g++-mp-4.7 -std=c++11 array.cpp -o array