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

Вниз

Кому и когда надо делать Canvas.Lock?   Найти похожие ветки 

 
Aleksandr ©   (2003-11-06 14:29) [0]

У меня несколько потоков обращаются к главному окну программы, у которого есть панель внизу. По их обращениям на этой панели создаются прогрессбары, показывающие ход выполнения потоков, а по их терминировании уничтожаются. Когда и у кого из объектов (главной формы, панели) надо делать лок канвы при создании, прорисовке и уничтожении прогрессбаров?


 
Palladin ©   (2003-11-06 16:08) [1]

ну представь себе что canvas енто туалет, рисование на canvas, это его посещение, вызов Lock это закрыть его дверь изнутри, а потоки это домочадцы...

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


 
Digitman ©   (2003-11-06 16:34) [2]


> Когда надо .. делать лок канвы


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

диспетчером-арбитром "сортира" уже сам по себе является цикл выбоки/диспетчеризации оконных сообщений осн.потока процесса, он (осн.код.поток) "блюдет" очередь обращений к VCL-контролам и не допустит бардака, если каждый доп.код.поток, заинтересованный в изменении св-в VCL-контролов, будет так же "блюсти" очередность, ставя свои запросы в общую очередь, а не пытаясь "внаглую" лезть в общий "сортир"

см. метод TThread.Synchronize(), который как раз и предназначен для этого


 
Aleksandr ©   (2003-11-06 16:53) [3]

Спасибо.



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

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

Наверх




Память: 0.47 MB
Время: 0.031 c
1-56666
Yanis
2003-11-05 10:15
2003.11.17
Prisoedinenie


3-56502
Behemoth
2003-10-28 08:52
2003.11.17
Удаление дублирующихся значений!


14-56812
Nick-From
2003-10-24 17:52
2003.11.17
FastReport для Delphi 7


3-56537
Yuri
2003-10-27 10:07
2003.11.17
обнулять автоинкрементное поле?


3-56498
Vick
2003-10-27 18:23
2003.11.17
Пропадает коннект с сервером SQL