当前页面: 开发资料首页 → Javascript 专题 → Javascript实例教程(21) OLE Automation(6)
Javascript实例教程(21) OLE Automation(6)
摘要: Javascript实例教程(21) OLE Automation(6)
6. 怎样提高脚本程序的性能
自从我们处理重的对象模型(比如Word.Application)和应用程序实例,注意系统的资源示相当重要的。一旦我们完成对应用程序实例的处理,我们必须去掉它,以从内存重清除对象的实例。在Jscript中有唯一的方法来实现,它就是应用程序对象的Quit()方法,以下是一个例子:
var wdApp = new ActiveXObject(Word.Application);
wdApp.Quit(); // tidy up
在Visual Basic中,不象Jscript和VBScript,设置对象变量为空是不能清除内存的。而且,如果没有其它对这个对象进行引用的话,这样的赋值操作将导致应用程序的关闭。不幸的是,在JSCript中我们必须使用Quit()方法在我们已经使用对象的时候来将它从内存中清除。而设置变量为零长度的字符串或者为空只是一个好的练习,它并不能起到清除内存的作用。
在教程中放置点至少代码了一个过程调用不得不在背景中被执行。最好得解决方法就是局部化高速缓冲对象引用。总得说来,这个技巧可以应用到对象以及Automation对象。下面看看脚本片段:
var exApp = new ActiveXObject(Excel.Application);
exApp.Workbooks(1).Worksheets(1).Cells(1, 1).Value = First Cell;
exApp.Workbooks(1).Worksheets(1).Cells(1, 2).Value = Second Cell;
exApp.Workbooks(1).Worksheets(1).Cells(1, 3).Value = Third Cell;
exApp.Workbooks(1).Worksheets(1).Cells(1, 4).Value = Fourth Cell;
exApp.Workbooks(1).Worksheets(1).Cells(1, 5).Value = Fifth Cell;
下面的代码说明了以更有效的方法来实现:
var exApp = new ActiveXObject(Excel.Application);
var exWbook = exApp.Workbooks(1).Worksheets(1);
exWbook.Cells(1, 1).Value = First Cell;
exWbook.Cells(1, 2).Value = Second Cell;
exWbook.Cells(1, 3).Value = Third Cell;
exWbook.Cells(1, 4).Value = Fourth Cell;
exWbook.Cells(1, 5).Value = Fifth Cell;
↑返回目录
前一篇:
Javascript实例教程(21) OLE Automation(7)
后一篇:
Javascript实例教程(21) OLE Automation(5)