当前位置: 首页 > 图文教程 > 开发语言 > Delphi > Action 造成cpu占用过多的奇怪问题

Delphi
闪动标题栏
制作真正的TopMost窗口
制作类似WinAmp一样的“磁性”窗口
不可移动的窗口示例代码
自制替换指定串函数
Delphi中RichEdit的奥妙
Delphi数据集过滤技巧
为VB应用程序定制浮动提示
DELPHI图形编辑技巧二则
Delphi使用技巧两则
Delphi 3.0中的函数调用模式
Delphi3中制作快速按钮条
Delphi 4增订的Object Pascal
Delphi3.0中的函数调用模式
DCU文件(编译的库单元)的重用
命令行参数的使用
在编译时获得提示
运行时生成控件
任意打印
分行提示

Delphi 中的 Action 造成cpu占用过多的奇怪问题


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-10-30   浏览: 117 ::
收藏到网摘: n/a

 
问题说明:

  为了维护程序的结构,我在程序中大量使用Action。其优点大家都知道,我可以让MenuItem对应某个Action,同时让工具栏上的Toolbutton也对于相同的Action。这样我只需要对Action进行编程,而MenuItemToolButton都可以相关到这个事件。

  不过我发现了一个非常奇怪的问题。当我在程序中创建了4个工具栏。然后初始化程序时动态创建ToolButton(大约40个),同时把他们都关联到不同的Action。(整个程序还只是一个空壳子,所有的Action里面还没有放入代码)我在主窗体上面的空白处(非工具栏区域)移动鼠标,用任务管理器监视。CPU占用率达30%左右(其他程序都关闭了)。如果我动态创建ToolButton的时候先关联Action,然后再取消管理Action,CPU占有率就下降到10%左右。

  解决思路:

  发现是由于在出发 WM_UPDATE 事件的时候,TActionManager会询问所有 TAction,是否需要响应 OnUpdate 事件。而这个 WM_UPDATE 触发的频率相当频繁,可想而知,不断对所有 TAction 进行询问,需要占用大量的 CPU 时间。在实际运用过程中,这个 OnUpdate 事件几乎不被用到。因此设计了如下的补丁程序。


  function TContainedAction.Update: Boolean;
  begin {
  Result := (ActionList <> nil) and ActionList.UpdateAction(Self) or
  Application.UpdateAction(Self) or inherited Update or
  (SendAppMessage(CM_ACTIONUPDATE, 0, Longint(Self)) = 1);
  }
  // ---------------------------------------------------------
  // OnUpdate may cause serious performance problem.
  // CPU usage is always at about 20-30% (AthlonXP 2100+)
  // ---------------------------------------------------------

  Result := False; // patched by 5291 2004-05-15
  end;

  把修改后的 ActnList.pas 拷贝到你的应用程序路径之下然后编译该程序。这个文件修改了原先的Update方法。你的程序可以直接使用新的 ActnList.dcu,你可以用它覆盖原先的组件。