|
Вопрос # 2 250/ вопрос открыт / |
|
Здравствуйте, уважаемые эксперты!
Мне в моей программе нужно засечь время в начале работы
т.е засечь время в начале ее работы T1 и в конце T2 и от одного отнять другое.
Проблема в точности. Т.е программа работает так быстро что T2-T1=0
Засекал функцией getTickCount
 |
Вопрос задал: Anderson N.N (статус: 2-ой класс)
Вопрос отправлен: 29 декабря 2008, 22:52
Состояние вопроса: открыт, ответов: 0.
|
Мини-форум вопроса
Всего сообщений: 3; последнее сообщение — 29 декабря 2008, 23:40; участников в обсуждении: 2.
|
Anderson N.N (статус: 2-ой класс), 29 декабря 2008, 23:03 [#1]:
Т.е как отловить еще более короткие промежутки времени чем Миллисекунды
|
|
Anderson N.N (статус: 2-ой класс), 29 декабря 2008, 23:20 [#2]:
да еще заметил что getTickCount срабатывает через 15миллисек
меньшие промежутки времени отслеживатье невозможно
|
|
Вадим К (статус: Академик), 29 декабря 2008, 23:40 [#3]:
Вообще то эта функция гарантирует интервал в 52мс, а на серверных вариантах - 130.
Если тестируем скорость выполнения алгоритма, то есть только один надёжный вариант - повторить выполненте 1000, 10000 раз. что бы насобиралось времени хотя бы на пару секунд.
Можно рискнуть и использовать специальную инструкцию процессора. Читать здесь
http://ru.wikipedia.org/wiki/Rdtsc
http://www.delphisources.ru/pages/faq/base/rdtsc.html
Но! надо помнить, что менеджер процессов в виндовс может переключать когда ему в голову прийдёт (ну разработчикам виндовс виднее, но для нас - пусть это будет случайный алгоритм, легче поверить и понять что делать). Поэтому, не надо будет удивляться, если результаты измерения будут отличаться каждый раз Ведь Вы думаете, что работает только Ваша программа, а в этот момент например злобный антивирус решил сделать проверку диска и тормознул программу.
Галочка "подтверждения прочтения" - вселенское зло.
|
Чтобы оставлять сообщения в мини-форумах, Вы должны авторизироваться на сайте.
|