Главная страница
Top.Mail.Ru    Яндекс.Метрика
Текущий архив: 2005.02.20;
Скачать: CL | DM;

Вниз

Продолжительность работы потока   Найти похожие ветки 

 
Mouserx   (2005-02-08 12:16) [0]

Мастера как узнать время работы потока? Меня волнует не время ЦП а просто продолжительность работы потока! Отслеживать мне надо посторонний поток, поэтому я не могу знать когда он запустился.


 
Digitman ©   (2005-02-08 12:19) [1]


> Отслеживать мне надо посторонний поток


своего процесса ? или чужого ?


 
Mouserx   (2005-02-08 12:24) [2]

Отслеживаю доп. поток своего процесса. Известно только ID доп. потока.


 
BiN ©   (2005-02-08 12:34) [3]

GetThreadTimes


 
Alexander Panov ©   (2005-02-08 12:42) [4]

t1=now
=WaitForSingleObject
t2=now

dt=t2-t1


 
Mouserx   (2005-02-08 13:01) [5]


> BiN ©   (08.02.05 12:34) [3]

А можно по подробнее как ее использовать? мне непонятны параметры которые ей надо передать (кроме первого).


> Alexander Panov ©   (08.02.05 12:42) [4]

Поток работает вместе с основной программой а не ждет (WaitForSingleObject)

Думал просто хранить время запуска потока, но потоков несколько и вот хочу знать:
Можно ли узнать время работы потока, нигде не записывая время его запуска?


 
Alexander Panov ©   (2005-02-08 13:05) [6]

Mouserx   (08.02.05 13:01) [5]
Можно ли узнать время работы потока, нигде не записывая время его запуска?


Можно.
При старте процедуры Execute запоминуешь время, при окончании - считаешь разницу. Результат получаешь в основном потоке.


 
Digitman ©   (2005-02-08 13:09) [7]


> Mouserx   (08.02.05 13:01) [5]


> Поток работает вместе с основной программой а не ждет (WaitForSingleObject)


когда он подобным образом "ждет", растет его kernel time.
когда он не "ждет", растет user time

суммарное время работы потока (ждет он или не ждет) равно сумме KernelTime + UserTime .. или ExitTime - CreationTime ..

до тех пор пока хэндл потока не закрыт, ты имеешь право и возможность с пом.вызова GetThreadTimes узнать все четыре временных параметра потока


 
Digitman ©   (2005-02-08 13:13) [8]


> Alexander Panov ©   (08.02.05 13:05) [6]
> При старте процедуры Execute запоминуешь время, при окончании
> - считаешь разницу


Execute не есть вся поточная ф-ция... это лишь процедура, вызываемая в контексте поточной ф-ции созданного потока

во многих случаях измерение времени выполнения собственно Execute не отражает сути вопроса автора, ибо м.б. существенно меньше реального времени выполнения поточной ф-ции из-за многих факторов ... например, использования синхронизации с потоком-создателем



Страницы: 1 вся ветка

Текущий архив: 2005.02.20;
Скачать: CL | DM;

Наверх




Память: 0.48 MB
Время: 0.071 c
14-1106821364
BiN
2005-01-27 13:22
2005.02.20
Фантастический роман или повесть. Может кто помнит?


14-1106762330
Nic87
2005-01-26 20:58
2005.02.20
Появился новый сайт по программированию!


14-1107252254
infom
2005-02-01 13:04
2005.02.20
Выскажите своё мнение или поделитесь опытом ... Ханты-Мансийск


14-1106816506
Andy BitOff
2005-01-27 12:01
2005.02.20
Опять вопросы по настройке локальной сети.


14-1104829079
www.Vlad.uk
2005-01-04 11:57
2005.02.20
Винда требует диск...