浏览 3921 次
锁定老帖子 主题:Openlaszlo应用初始化性能优化过程
精华帖 (0) :: 良好帖 (0) :: 新手帖 (0) :: 隐藏帖 (0)
|
|
---|---|
作者 | 正文 |
发表时间:2007-03-27
在开发openlaszlo应用过程中,往往考虑的是功能是否能正常实现,除了遵守openlaszlo开发规范外,对性能方面考虑的比较少,但是随着应用规模的增加,到了后期测试的时候就会发现性能问题已经很严重了,这时要对系统进行性能调整,这是openlaszlo开发过程中不可缺少的一部分。
下面以笔者开发的一个配置工具为例说明openlaslzo性能调优过程: (测试环境:赛扬2.42/1.5G RAM/winxp sp2/IE7) 系统未优化前,初始化时间6.37秒(含debug窗口),主程序总共有10个对话框窗口(modaldialog),代码总行数近千行。 第一阶段:初步优化 1。将所有的modaldialog设置其initstage="defer" 初步优化后初始化时间为2秒 2。当主题数据取来后,进行初始化themetreedialog: canvas.themetreedialog.completeInstantiation(); 3。在所有操作按钮上添加对应的窗口初始化声明: canvas.adddirdialog.completeInstantiation(); ... 4。窗口内打开过滤器设定窗口时,进行初始化: canvas.addconditiondialog.completeInstantiation(); 5。单击表格行打开修改过滤窗口时,进行初始化: canvas.filterModWin.completeInstantiation(); 优化结果: 系统在2.09秒之内初始化完成(含debug窗口),不包括debug窗口的初始化时间与包括时非常接近,但是包含debug的swf文件尺寸要大142K。 所有的窗口延迟初始化设置完成,进行测试发现,当对话框内容较少时,初始化过程非常短暂,但是过滤器设定窗口的初始化过程稍微长点在1秒左右,但是初始化一次以后,再打开就非常快,由此可见openlaszlo的初始化过程只进行一次,不会重复进行。 此外,这种利用开启窗口的前夕来初始化对话框的方法还有局限性,如果窗口内容比较多,那么初始话 过程足以造成相应迟钝,造成体验不好,还应该进行继续探索。 第二阶段:深度优化 经过仔细分析发现,在获取远程数据过程中有少许间隙时间,可以利用这个间隙来初始化比较大的modaldialog,选择其中一个只获取一次数据的dataset来初始化过滤器窗口,经过反复测量初始化时间,认定该步优化后的应用初始化时间与上一个过程时间一致。 去掉原来加在按钮上的初始化过滤器窗口声明,完成整个优化过程。 调整过程原则总结: 1。当前不显示的窗口不在系统初始化时生成 2。只在需要的时候才生成窗口或者视图 3。充分利用事件进行completeInstantiation 4。充分利用系统闲暇时间 声明:ITeye文章版权属于作者,受法律保护。没有作者书面许可不得转载。
推荐链接
|
|
返回顶楼 | |
发表时间:2007-03-31
向LZ学习了 最近换了工作 现在要用的正是OpenLaszlo 我现在还是个新手 希望以后能和LZ多多交流啊
|
|
返回顶楼 | |