![]() |
|
|
|||||||
| Регистрация | << Правила форума >> | FAQ | Пользователи | Календарь | Поиск | Сообщения за сегодня | Все разделы прочитаны |
![]() |
|
|
Опции темы | Поиск в этой теме | Опции просмотра |
|
#1
|
|||
|
|||
|
Для своей программы хочу использовать потоки. Т.к. работаю с визуальными компонентами, то приходиться использовать метод Synchronize. Программа работает нормально, НО Delphi, почемуто подчеркивает Synchronize красным и пишет
Цитата:
Вопросы: 1. С чем это может быть связано? 2. Как это исправить? 3. Почему заведомо описанный метод отмечается как не описанный? ![]() Последний раз редактировалось ProperDoze, 11.09.2008 в 21:22. |
|
#2
|
|||
|
|||
|
Как запустить поток повторно?
![]() |
|
#3
|
|||
|
|||
|
Если он закончился, то только повторно его создав.
|
|
#4
|
|||
|
|||
|
Цитата:
А как быть с Synchronize? Мне кажется, что мой поток не работает, как нужно. Потому, что без Application.ProcessMessages Форму не прорисовывает. Что делать? |
|
#5
|
|||
|
|||
|
Как я могу тебе сказать, что ты делаешь не так, если я не вижу что и как ты делаешь? Код приведи, бум смотреть.
|
|
#6
|
|||
|
|||
|
Цитата:
Ок. Код:
unit Thread_Chart_repaint;
interface
uses
Classes;
type
Repaint_Charts = class(TThread)
private
{ Private declarations }
protected
procedure Execute; override;
public
Processing: boolean;
end;
implementation
uses converter;
{ Important: Methods and properties of objects in visual components can only be
used in a method called using Synchronize, for example,
Synchronize(UpdateCaption);
and UpdateCaption could look like,
procedure Repaint_Charts.UpdateCaption;
begin
Form1.Caption := 'Updated in a thread';
end; }
{ Repaint_Charts }
procedure Repaint_Charts.Execute;
begin
//while not Terminated do
//while Processing do
Synchronize(Charts_panel.Paint_charts);
end;
end.Synchronize подчеркнуто красным, но код исполняется. |
|
#7
|
|||
|
|||
|
Скорее всего, она предупреждает тебя, что потенциально возможны проблемы, т.к. Synchronize в принципе предназначена для выполнения методов потока. А вот уже из метода потока, можно спокойно "дергать" что угодно.
|
|
#8
|
|||
|
|||
|
Цитата:
Тогда, почему она пишет "Undeclared identifier" а не какой нибудь варнинг??! А также, поток работает, на мой взгляд, не так, как надо. Это выражается в том, что без потока, все работает аналогично!!!! Т.е. без применения Application.ProcessMessages события формы не "ловятся" и стало быть форма "сама" не прорисовывается. З.Ы. Например, в даунлоад-мастере когда окно с загрузкой двигаешь по экрану, загрузка не приостанавливается, а это, на мой взгляд, говорит о том, что там используются как минимум потоки и никакого Application.ProcessMessages, т.к. он такого эффекта не дает. Последний раз редактировалось ProperDoze, 15.09.2008 в 15:13. |
|
#9
|
|||
|
|||
|
Кто нибудь может привести в пример код простой программы, где потоки нормально работают?!
![]() |
|
#10
|
|||
|
|||
|
Вычисление числа ПИ
Главная форма Код:
unit uMain;
interface
uses
Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Forms,
Dialogs, StdCtrls,
uPiThread;
type
TfmMain = class(TForm)
cbCalculate: TCheckBox;
Label1: TLabel;
Label2: TLabel;
laBuiltIn: TLabel;
laValue: TLabel;
laIterNum: TLabel;
procedure FormCreate(Sender: TObject);
procedure cbCalculateClick(Sender: TObject);
private
{ Private declarations }
public
{ Public declarations }
PiThread : TPiThread;
procedure UpdatePi;
end;
var
fmMain: TfmMain;
implementation
{$R *.dfm}
procedure TfmMain.UpdatePi;
begin
if IsIconic( Application.Handle ) then
Exit;
LaValue.Caption := FloatToStrF( GlobalPi, ffFixed, 18, 18 );
laIterNum.Caption := IntToStr( GlobalCounter ) + ' iterations';
end;
procedure TfmMain.FormCreate(Sender: TObject);
begin
laBuiltIn.Caption := FloatToStrF( Pi, ffFixed, 18, 18 );
end;
procedure TfmMain.cbCalculateClick(Sender: TObject);
begin
if cbCalculate.Checked then
begin
PiThread := TPiThread.Create( True );
PiThread.FreeOnTerminate := True;
PiThread.Priority := tpLower;
PiThread.Resume;
end
else
begin
if Assigned( PiThread ) then PiThread.Terminate;
end;
end;
end.Поток Код:
unit uPiThread;
interface
uses
Classes;
type
TPiThread = class(TThread)
private
{ Private declarations }
protected
procedure Execute; override;
end;
var
GlobalPi : Extended;
GlobalCounter : Int64;
implementation
uses uMain;
const
UpdatePeriod = 999999;
procedure TPiThread.Execute;
var sign : Integer;
PiValue, PrevValue : Extended;
i : Int64;
begin
PiValue := 4;
sign := -1;
i := 0;
repeat
Inc(i);
PrevValue := PiValue;
PiValue := PiValue + sign * 4 / (2*i+1);
sign := -sign;
if i mod UpdatePeriod = 0 then
begin
GlobalPi := PiValue;
GlobalCounter := i;
Synchronize( fmMain.UpdatePi );
end;
until Terminated or
(Abs(PiValue - PrevValue)<1E-19) ;
end;
end. |