以下内容仅供初学者参考
看到有的同学对Delphi的线程认识不够深,特开一贴给同学们讲讲。
主要给出两种常用的线程形式。
1、长等待型线程示例,等待命令,执行不定长的工作,但每个工作的时间不会太长。
2、长工作型线程示例,执行一个很长时间的工作,但可以很快响应取消操作。
注:对于在线程中取消存储过程的执行仍然无解
以下程序所用的知识为:消息机制以及常用的API函数
主程序Unit1
线程类:
看到有的同学对Delphi的线程认识不够深,特开一贴给同学们讲讲。
主要给出两种常用的线程形式。
1、长等待型线程示例,等待命令,执行不定长的工作,但每个工作的时间不会太长。
2、长工作型线程示例,执行一个很长时间的工作,但可以很快响应取消操作。
注:对于在线程中取消存储过程的执行仍然无解
以下程序所用的知识为:消息机制以及常用的API函数
主程序Unit1
-
Delphi(Pascal) code
-
unit Unit1; interface uses Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Forms, Dialogs, StdCtrls,LongWaitTrd; type TForm1 = class(TForm) btnSetTask: TButton; btnExitThd: TButton; btnCreateTrd: TButton; procedure btnSetTaskClick(Sender: TObject); procedure btnCreateTrdClick(Sender: TObject); procedure btnExitThdClick(Sender: TObject); private LongWaitThread:TLongWaitTrd; procedure OnThreadMessage( var Message: TMessage); message WM_USER + 2000 ; public { Public declarations } end ; var Form1: TForm1; implementation { $R *.dfm } procedure TForm1.btnSetTaskClick(Sender: TObject); begin if (LongWaitThread <> nil ) then PostThreadMessage(LongWaitThread.ThreadID,WM_USER + 1000 , 0 , 0 ); end ; procedure TForm1.btnCreateTrdClick(Sender: TObject); begin LongWaitThread: = TLongWaitTrd.Create(true); LongWaitThread.MainWin: = Handle; LongWaitThread.Resume; end ; procedure TForm1.OnThreadMessage( var Message: TMessage); begin if Message.Msg = WM_USER + 2000 then begin Showmessage(String(message.LParam)); end ; end ; procedure TForm1.btnExitThdClick(Sender: TObject); begin if (LongWaitThread <> nil ) then begin if ( not LongWaitThread.ExitLongWaitTrd()) then ShowMessage( ' The thread exited time out ' ); end ; end ; end .
线程类:
-
Delphi(Pascal) code
-
unit LongWaitTrd; interface uses Classes,Windows,Messages,SyncObjs; type TLongWaitTrd = class(TThread) private FMainWin:THandle; QuitEvent: TEvent; procedure SendFeedBackToMainWin(); procedure DoTheHardWork(); protected procedure Execute; override; public constructor Create(CreateSuspended: Boolean); destructor Destroy; override; function ExitLongWaitTrd():Boolean; published property MainWin:THandle read FMainWin write FMainWin; end ; implementation uses Unit1; constructor TLongWaitTrd.Create(CreateSuspended: Boolean); begin inherited Create(CreateSuspended); end ; destructor TLongWaitTrd.Destroy; begin inherited; end ; procedure TLongWaitTrd.DoTheHardWork(); begin // to do end ; procedure TLongWaitTrd.Execute; var Msg: TMsg; begin FreeOnTerminate: = True; // 1 .长等待型线程示例 // while GetMessage(Msg, 0 , 0 , 0 ) do // begin // if (Msg.message = WM_USER + 1000 ) then // 任务来了 // begin // DoTheHardWork(); // SendFeedBackToMainWin; // end ; // if (Msg.message = WM_QUIT) then // begin // QuitEvent.SetEvent; // Break; // end ; // end ; // 2 .长工作型线程示例 // while (true) do // begin // if PeekMessage(Msg, 0 , 0 , 0 , PM_REMOVE) then // begin // if (Msg.message = WM_QUIT) then // begin // QuitEvent.SetEvent; // Break; // end ; // end ; // DoTheHardWork(); // end ; end ; function TLongWaitTrd.ExitLongWaitTrd; begin Result: = true; QuitEvent: = TEvent.Create( nil ,True,False, ' QuitEvent ' ); PostThreadMessage(ThreadID,WM_QUIT, 0 , 0 ); if (QuitEvent.WaitFor( 2000 ) = wrTimeOut) then Result: = false; QuitEvent.Free ; end ; procedure TLongWaitTrd.SendFeedBackToMainWin(); var Status:String; begin if (MainWin <> 0 ) then begin Status: = ' The data has been processed by thread. ' ; PostMessage(MainWin,WM_USER + 2000 , 0 ,Integer(Status)) end ; end ; end .