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

Вниз

Синхронизация по времени выполнения.   Найти похожие ветки 

 
debuger ©   (2004-10-28 18:28) [0]

Доброго всем всего.
Есть три процедуры. Одна должна выполнятся 15 раз в секунду, вторая 5 раз в секунду, а ретья по возможности на заднем плане.
Довольно идейно все оформить потоками.
Как это все синхронизировать? Т.е. что-бы первая выполнялясь строго 15 раз в секунду(через каждые 66 мс) и т.д. Конечно же если выполнение процедуры не закончилось, то ее следующее выполнение откладывается до завершения предидущей копии.

Пасиба.


 
debuger ©   (2004-10-28 20:52) [1]

Идейно ли заводить несколько таймеров?


 
Palladin ©   (2004-10-28 22:07) [2]

Довольно строго не получится изза ограничений системы, Windows всетаки далеко не RT. Это во первых, во вторых, если тело процедуры должной выполнятся каждые Nмс выполняется Mмс, где M>N (даю 80% вероятности про 66мс), то естественно выполнять его каждые Nмс не получится. В третьих при использовании таймера событие совсем не обязательно исполнится точно через прошедший интервал. Лучше использовать потоки совместно со Sleep. Но требуемой точности все равно не достигнешь.

Как достичь синхронности выполнения с максимальной точностью. Для этого на все это дело нужно завести один синхронизирующий поток со Sleep(<НОД для всех интервалов>) и соответсвенно считать, считать и еще раз считать, при досчете до нужного интервала для какой либо процедуры запустить (Resume) тот поток который должен это выполнить. Почему нельзя реализовать все процедуры в синхронизирующем потоке. Потому что возникнет погрешность в осчете интервалов при выполнении процедур, они же тоже какое то время занимают. Погрешности не избежать и при процедурах сидящих в разных потоках, но в этом случае она будет меньше.



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

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

Наверх




Память: 0.47 MB
Время: 0.032 c
14-1098383173
SviL
2004-10-21 22:26
2004.11.14
Хочу найти компоненты


14-1098875375
alles
2004-10-27 15:09
2004.11.14
Трабл с Default


3-1097824819
NorthMan
2004-10-15 11:20
2004.11.14
Запрос из консольного приложения


3-1097566777
by
2004-10-12 11:39
2004.11.14
Использование естественных ключей допустимо?


3-1097573274
Санёк
2004-10-12 13:27
2004.11.14
MSSQL и SQLTimeStamp