gettimeofday (), вероятно, сделает то, что вы хотите.
Если вы используете аппаратное обеспечение Intel, здесь показано, как считать счетчик команд процессора в реальном времени. Он сообщит вам количество циклов ЦП, выполненных с момента загрузки процессора. Это, вероятно, самый мелкозернистый счетчик накладных расходов, который вы можете получить для измерения производительности.
Обратите внимание, что это количество циклов ЦП. В Linux вы можете получить скорость процессора из / proc / cpuinfo и разделить, чтобы получить количество секунд. Преобразовать это в двойное довольно удобно.
Когда я запускаю это на своей коробке, я получаю
11867927879484732
11867927879692217
it took this long to call printf: 207485
Вот руководство для разработчиков Intel , в котором содержится множество деталей.
#include <stdio.h>
#include <stdint.h>
inline uint64_t rdtsc() {
uint32_t lo, hi;
__asm__ __volatile__ (
"xorl %%eax, %%eax\n"
"cpuid\n"
"rdtsc\n"
: "=a" (lo), "=d" (hi)
:
: "%ebx", "%ecx");
return (uint64_t)hi << 32 | lo;
}
main()
{
unsigned long long x;
unsigned long long y;
x = rdtsc();
printf("%lld\n",x);
y = rdtsc();
printf("%lld\n",y);
printf("it took this long to call printf: %lld\n",y-x);
}