| 
| 
 | Вопрос # 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
 Но! надо помнить, что менеджер процессов в виндовс может переключать когда ему в голову прийдёт (ну разработчикам виндовс виднее, но для нас - пусть это будет случайный алгоритм, легче поверить и понять что делать). Поэтому, не надо будет удивляться, если результаты измерения будут отличаться каждый раз
  Ведь Вы думаете, что работает только Ваша программа, а в этот момент например злобный антивирус решил сделать проверку диска и тормознул программу. Галочка "подтверждения прочтения" - вселенское зло. |  Чтобы оставлять сообщения в мини-форумах, Вы должны авторизироваться на сайте. |