Как уже отмечали другие, функция time () в стандартной библиотеке C не имеет разрешения лучше, чем одна секунда. Похоже, единственной полностью переносимой функцией C, которая может обеспечить лучшее разрешение, является clock (), но она измеряет время процессора, а не время настенных часов. Если кто-то хочет ограничиться платформой POSIX (например, Linux), то функция clock_gettime () - хороший выбор.
Начиная с C ++ 11, есть гораздо лучшие средства синхронизации , которые предлагают лучшее разрешение в форме, которая должна быть очень переносимой для различных компиляторов и операционных систем. Точно так же библиотека boost :: datetime предоставляет хорошие классы синхронизации высокого разрешения, которые должны быть легко переносимыми.
Одной из проблем при использовании любого из этих средств является задержка, вызванная запросом системных часов. Из экспериментов с clock_gettime (), boost :: datetime и std :: chrono эта задержка может легко составлять несколько микросекунд. Таким образом, при измерении длительности любой части вашего кода вы должны учитывать наличие ошибки измерения около этого размера или пытаться каким-то образом исправить эту нулевую ошибку. В идеале может потребоваться собрать несколько измерений времени, затраченного вашей функцией, и вычислить среднее или максимальное / минимальное время, затраченное на несколько прогонов.
Чтобы решить все эти проблемы переносимости и сбора статистики, я разрабатывал библиотеку cxx-rtimers, доступную в Github , которая пытается предоставить простой API для блоков синхронизации кода C ++, вычисляя ноль ошибки и отчеты о статистике от нескольких таймеров, встроенных в ваш код. Если у вас есть компилятор C ++ 11, вы просто #include <rtimers/cxx11.hpp>
и используете что-то вроде:
void expensiveFunction() {
static rtimers::cxx11::DefaultTimer timer("expensiveFunc");
auto scopedStartStop = timer.scopedStart();
// Do something costly...
}
При выходе из программы вы получите сводную статистику по времени, записанную в std :: cerr, такую как:
Timer(expensiveFunc): <t> = 6.65289us, std = 3.91685us, 3.842us <= t <= 63.257us (n=731)
, который показывает среднее время, его стандартное отклонение, верхний и нижний пределы и количество раз, когда эта функция была вызвана.
Если вы хотите использовать специфичные для Linux функции синхронизации, вы можете #include <rtimers/posix.hpp>
или, если у вас есть библиотеки Boost, но более старый компилятор C ++, вы можете #include <rtimers/boost.hpp>
. Существуют также версии этих классов таймеров, которые могут собирать статистическую информацию о времени из разных потоков. Существуют также методы, позволяющие оценить нулевую ошибку, связанную с двумя непосредственно последовательными запросами системных часов.