Results:
Vector time: 7051
Array time: 18944
I used MSVC release mode for this, compiled as 32 bit.
Before this test I was looking at the GCC source code for vector and was surprised because I thought operator[] checked for array-out-of-bounds, but it doesn't. However, I was not expecting the vector to be so fast?!
Complete code:
#include <iostream>
#include <vector>
int main(){
const int size = 10000;
unsigned long long my_array[size];
std::vector<unsigned long long> my_vec;
my_vec.resize(size);
//Populate containers
for(int i=0; i<size; i++){
my_vec[i] = i;
my_array[i] = i;
}
//Initialise test variables
unsigned long long sum = 0;
unsigned long long time = 0;
unsigned long long start = 0;
unsigned long long finish = 0;
//Time the vector
start = __rdtsc();
for(int i=0; i<size; i++){
sum += my_vec[i];
}
finish = __rdtsc();
time = finish - start;
std::cout << "Vector time: " << time << " " << sum << std::endl;
sum = 0;
//Time the array
start = __rdtsc();
for(int i=0; i<size; i++){
sum += my_array[i];
}
finish = __rdtsc();
time = finish - start;
std::cout << "Array time: " << time << " " << sum << std::endl;
int t = 8;
std::cin >> t;
return 0;
}
The following is using MSVC 2013.
For the vector:
0019138E mov edi,edi
for (int i = 0; i<size; i++){
00191390 lea ecx,[ecx+20h]
sum += my_vec[i];
00191393 movdqu xmm0,xmmword ptr [ecx-20h]
00191398 paddq xmm1,xmm0
0019139C movdqu xmm0,xmmword ptr [ecx-10h]
001913A1 paddq xmm2,xmm0
001913A5 dec esi
001913A6 jne main+0F0h (0191390h)
}
For the array:
0019142D lea ecx,[ecx]
for (int i = 0; i<size; i++){
00191430 lea ecx,[ecx+20h]
sum += my_array[i];
00191433 movdqu xmm0,xmmword ptr [ecx-30h]
00191438 paddq xmm1,xmm0
0019143C movdqu xmm0,xmmword ptr [ecx-20h]
00191441 paddq xmm2,xmm0
00191445 dec esi
00191446 jne main+190h (0191430h)
}
As you can see, the inner loops are identical. Actually, suspecting it was a hardware thing I swapped the two loops around and arrays came out faster to the same margin (so actually, neither is faster or slower than the other in the real world).
I predict this is some kind of CPU cache behavior: https://en.wikipedia.org/wiki/CPU_cache
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With