如何提高vba代码的运行速度

如何提高vba代码的运行速度

ID:1544923

大小:45.00 KB

页数:9页

时间:2017-11-12

如何提高vba代码的运行速度_第1页
如何提高vba代码的运行速度_第2页
如何提高vba代码的运行速度_第3页
如何提高vba代码的运行速度_第4页
如何提高vba代码的运行速度_第5页
资源描述:

《如何提高vba代码的运行速度》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库

1、如何提高代码的运行速度(VB/access Vba)本文描述了如何通过一些技术手段来提高编程代码的执行效率。这些手段可以分为两个大的部分:编码技术和编译优化技术。本文从编码技术和编译技术来讨论。大家发现有好的代码,也请回贴或更新。  第一部分:编码技术。下面的这些方法(到现在为止共27种)可以帮助你提高代码的运行速度:  1.使用整数(Integer)和长整数(Long)  提高代码运行速度最简单的方法莫过于使用正确的数据类型了。也许你不相信,但是正确地选择数据类型可以大幅度提升代码的性能。在大多数情况下,程序员可以将

2、Single,Double和Currency类型的变量替换为Integer或Long类型的变量,因为VB处理Integer和Long的能力远远高于处理其它几种数据类型。下面是排序:Long最快Integer.Byte.Single.Double.Currency最慢  在大多数情况下,程序员选择使用Single或Double的原因是因为它们能够保存小数。但是小数也可以保存在Integer类型的变量中。例如程序中约定有三位小数,那么只需要将保存在Integer变量中的数值除以1000就可以得到结果。根据我的经验,使用In

3、teger和Long替代Single,Double和Currency后,代码的运行速度可以提高将近10倍。  2.避免使用变体  对于一个VB程序员来说,这是再明显不过的事情了。变体类型的变量需要16个字节的空间来保存数据,而一个整数(Integer)只需要2个字节。通常使用变体类型的目的是为了减少设计的工作量和代码量,也有的程序员图个省事而使用它。但是如果一个软件经过了严格设计和按照规范编码的话,完全可以避免使用变体类型。  在这里顺带提一句,对于Object对象也存在同样的问题。请看下面的代码:DimFSOSetF

4、SO=NewScripting.FileSystemObject  或DimFSOasobjectSetFSO=NewScripting.FileSystemObject  上面的代码由于在申明的时候没有指定数据类型,在赋值时将浪费内存和CPU时间。正确的代码应该象下面这样:DimFSOasNewFileSystemObject  3.尽量避免使用属性  在平时的代码中,最常见的比较低效的代码就是在可以使用变量的情况下,反复使用属性(Property),尤其是在循环中。要知道存取变量的速度是存取属性的速度的20倍左右。

5、下面这段代码是很多程序员在程序中会使用到的:DimintConasIntegerForintCon=0toUbound(SomVar())Text1.Text=Text1.Text&vbcrlf&SomeVar(intCon)NextintCon  下面这段代码的执行速度是上面代码的20倍。DimintConasIntegerDimsOutputasStringForintCon=0toUbound(SomeVar())sOutput=sOutput&vbCrlf&SomeVar(intCon)NextText1.Te

6、xt=sOutput同样地,像这样的代码...DoUntilEOF(F)  LineInput#F,nextLine  Text1.Text=Text1.Text+nextLineLoop...比下面的代码慢得多:DoUntilEOF(F)  LineInput#F,nextLine  bufferVar=bufferVar+nextLineLoopText1.Text=bufferVar然而,下面的代码完成了相同的功能,而且还要快:  Text1.Text=Input(F,LOF(F))如上述,几种方法都实现了同样的

7、任务;同时,最好的算法也是最优的。  4.尽量使用数组,避免使用集合  除非你必须使用集合(Collection),否则你应该尽量使用数组。据测试,数组的存取速度可以达到集合的100倍。这个数字听起来有点骇人听闻,但是如果你考虑到集合是一个对象,你就会明白为什么差异会这么大。  5.展开小的循环体  在编码的时候,有可能遇到这种情况:一个循环体只会循环2到3次,而且循环体由几行代码组成。在这种情况下,你可以把循环展开。原因是循环会占用额外的CPU时间。但是如果循环比较复杂,你就没有必要这样做了。  6.避免使用很短的函

8、数  和使用小的循环体相同,调用只有几行代码的函数也是不经济的--调用函数所花费的时间或许比执行函数中的代码需要更长的时间。在这种情况下,你可以把函数中的代码拷贝到原来调用函数的地方。  7.减少对子对象的引用  在VB中,通过使用.来实现对象的引用。例如:Form1.Text1.Text  在上面的例子中,程序引用了两个对象:F

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。