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

Вниз

Каким образом правильно синхронизировать функцию потока?   Найти похожие ветки 

 
dimonf ©   (2003-06-20 11:49) [0]

Я создаю свой компанент TComponent.
При Create компонента создаю поток методом:
FThread := CreateThread(nil,0,@MonitorThread,FParamPtr,0,FThreadBaseId);
И описываю саму функцию потока: function MonitorThread(Prm : Pointer) : DWORD; stdcall;
begin
end;
Как правильно мне сослаться на процедуры моего TComponentа из функции потока??? Я знаю что для THread есть функция Synchronize(Self.DoSomething), а какая функция синхронизации есть для API???


 
Polevi ©   (2003-06-20 14:01) [1]

в твоем компоненте должен быть цикл ожидания уведомлений из потока
проще всего создать в нем окно и из потока посылать сообщения этому окну (SendMessage) - в данном случае цикл реализовывать не нужно, он уже есть
протокол придумай сам, например в lParam например номер ф-ии, в wParam - указатель на данные

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

PS
можно передавать не номер ф-ии а ее адрес, в таком случае удобно использовать TMethod


 
Digitman ©   (2003-06-20 15:01) [2]


> dimonf


объясни, какой ощутимый выигрыш ты получаешь, фактически используя стандартную библиотеку классов и отказываясь при этом от класса TThread в пользу прямого WinAPI-вызова в части работы с тредом ?



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

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

Наверх




Память: 0.47 MB
Время: 0.019 c
3-68210
Magic&Wizard
2003-07-28 11:24
2003.08.21
FireBird 1.5 vs InterBase 7.0


3-68165
s_ser
2003-07-28 19:50
2003.08.21
Забрать данные из BLOB поля


3-68175
KSergey
2003-07-28 17:48
2003.08.21
Выход из формы по Default-кнопке и сохранене данных..


3-68170
Lenid
2003-07-28 21:22
2003.08.21
Сложный динамический запрос SQL (со значениями всех или 1 edita)


3-68157
-Felan-
2003-07-28 13:43
2003.08.21
Помогите разобраться в запросе SQL