问题说明:
为了维护程序的结构,我在程序中大量使用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; |
Java Asp PHP .Net XML C/C++ CGI VB Jsp J2ee J2se J2me EJB Servlet Tomcat Resin Struts Weblogic Eclipse ANT GUI JMS Web servise IDEA Webphere Hibernate Spring Jboss Applet Swing Socket Javamail Perl Ajax P2P 安全 模式 框架 测试 开源 游戏
Windows XP Windows 2000 Windows 2003 Windows Me Windows 9.x Linux UNIX 注册表 操作系统 服务器 应用服务器