Delphi Dll中多线程无法使用Synchronize同步的解决方法(转)

具体原因可以参考这篇文章
“DLL/ActiveForm中的线程同步处理”www.delphibbs.com/keylife/iblog_show.asp。

事实上,经试验可以在dll工程文件中加入以下语句 :

Application.Initialize;

if Application.Handle = 0 then
begin
    Application.CreateHandle;
end;

Application.Run;

解决线程中使用Synchronize 假死的问题,或者在线程中直接使用SendMessage替代Synchronize
同步。

原因在于若工程文件是DLL而不是EXE的话,Application默认不创建窗口句柄,因此Synchronize
向Application发送消息根本无法响应,手动创建句柄,并让其进入消息循环状态可以解决

转自http://hi.baidu.com/ferrylife/blog/item/c3a9ab51dc359e888d543021.html

用以上方法。会因为application的值不同而在任务栏上产生两个按钮
function SetApplicationHandle(AppHandle: THandle): Boolean; stdcall;
begin
  try
    Application.Initialize;
    if Application.Handle = 0 then
      begin
        Application.CreateHandle;
      end;
    Application.Handle:= AppHandle;
    Application.Run;
    Result:= True;
  except
    Result:= False;
  end;
end;


在dll中导入一个函数
在主线程中调用传入application.handle使任务栏按钮变回一个


type
    TExportEmuFormApplication = function(AppHandle: THandle): Boolean; stdcall;

......
private
    FAppHandle: TExportEmuFormApplication;
    FDLLHandle: THandle;
......


implementation

constructor TEmuMap.Create(aParent: TComponent);
begin
  FDLLHandle := LoadLibrary('emudll.dll');
  try
    FAppHandle:= GetProcAddress(FDLLHandle, 'SetApplicationHandle');

    if not (@FAppHandle = nil) then
      begin
        FAppHandle(Application.Handle);
      end;

......
end;

本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/tomliks/archive/2009/08/07/4421347.aspx

 

PS: 如果用了FASTMM4,替换Application.Handle会出错!

所以可以用

在工程里家Application.MainFormOnTaskBar:= False ;

在onshow 里加入:ShowWindow(Application.Handle, SW_HIDE); //不在任务栏显示

posted @ 2010-09-28 17:19  Enli  阅读(5225)  评论(0编辑  收藏  举报