首页 > 开发 > 综合 > 正文

如何编写高质量的VB代码(2)

2024-07-21 02:20:56
字体:
来源:转载
供稿:网友
如何编写高质量的vb代码(2)

12. 销毁对象
  无论编写的是什么软件,程序员都需要考虑在用户决定终止软件运行后释放软件占用的内存空间。但遗憾的是很多程序员对这一点好像并不是很在意。正确的做法是在退出程序前需要销毁程序中使用的对象。例如:
dim fso as new filesystemobject
注释: 执行操作
注释: 销毁对象
set fso = nothing
对于窗体,可以进行卸载:
unload frmmain
  或
set frmmain = nothing
  13. 变长和定长字符串
  从技术上来说,与变长字符串相比,定长字符串需要较少的处理时间和空间。但是定长字符串的缺点在于在很多情况下,你都需要调用trim函数以去除字符串末的空字符,这样反而会降低代码效率。所以除非是字符串的长度不会变化,否则还是使用变长字符串。
  14. 使用类模块,而不是activex控件
  除非activex控件涉及到用户界面,否则尽量使用轻量的对象,例如类。这两者之间的效率有很大差异。
  15. 使用内部对象
  在涉及到使用activex控件和dll的时候,很多程序员喜欢将它们编译好,然后再加入工程中。我建议你最好不要这样做,因为从vb连接到一个外部对象需要耗费大量的cpu处理能力。每当你调用方法或存取属性的时候,都会浪费大量的系统资源。如果你有activex控件或dll的源代码,将它们作为工程的私有对象。
  16. 减少模块的数量
  有些人喜欢将通用的函数保存在模块中,对于这一点我表示赞同。但是在一个模块中只写上二三十行代码就有些可笑了。如果你不是非常需要模块,尽量不要使用它。这样做的原因是因为只有在模块中的函数或变量被调用时,vb才将模块加载到内存中;当vb应用程序退出时,才会从内存中卸载这些模块。如果代码中只有一个模块,vb就只会进行一次加载操作,这样代码的效率就得到了提高;反之如果代码中有多个模块,vb会进行多次加载操作,代码的效率会降低。
  17. 使用对象数组
  当设计用户界面时,对于同样类型的控件,程序员应该尽量使用对象数组。你可以做一个实验:在窗口上添加100个picturebox,每个picturebox都有不同的名称,运行程序。然后创建一个新的工程,同样在窗口上添加100个picturebox,不过这一次使用对象数组,运行程序,你可以注意到两个程序加载时间上的差别。
  18. 使用move方法
  在改变对象的位置时,有些程序员喜欢使用width,height,top和left属性。例如:
image1.width = 100
image1.height = 100
image1.top = 0
image1.left = 0
  实际上这样做效率很低,因为程序修改了四个属性,而且每次修改之后,窗口都会被重绘。正确的做法是使用move方法:
image1.move 0,0,100,100
  19. 减少图片的使用
  图片将占用大量内存,而且处理图片也需要占用很多cpu资源。在软件中,如果可能的话,可以考虑用背景色来替代图片--当然这只是从技术人员的角度出发看这个问题。
  20. 使用activex dll,而不是activex控件
  如果你设计的activex对象不涉及到用户界面,使用activex dll。
  编译优化
  我所见过的很多vb程序员从来没有使用过编译选项,也没有试图搞清楚各个选项之间的差别。下面让我们来看一下各个选项的具体含义。
  1. p-代码(伪代码)和本机代码
  你可以选择将软件编译为p-代码或是本机代码。缺省选项是本机代码。那什么是p-代码和本机代码呢?
p-代码:当在vb中执行代码时,vb首先是将代码编译为p-代码,然后再解释执行编译好的p-代码。在编译环境下,使用这种代码要比本机代码快。选择p-代码后,编译时vb将伪代码放入一个exe文件中。
  本机代码:本机代码是vb6以后才推出的选项。当编译为exe文件后,本机代码的执行速度比p-代码快。选择本机代码后,编译时vb使用机器指令生成exe文件。
  在使用本机代码进行编译时,我发现有时候会引入一些莫名其妙的错误。在编译环境中我的代码完全正确地被执行了,但是用本机代码选项生成的exe文件却不能正确执行。通常这种情况是在卸载窗口或弹出打印窗口时发生的。我通过在代码中加入doevent语句解决了这个问题。当然出现这种情况的几率非常少,也许有些vb程序员从来没有遇到过,但是它的确存在。

  在本机代码中还有几个选项:
  a) 代码速度优化:该选项可以编译出速度较快的执行文件,但执行文件比较大。推荐使用
  b) 代码大小优化:该选项可以编译出比较小的执行文件,但是以牺牲速度为代价的,不推荐使用。
  c) 无优化:该选项只是将p-代码转化为本机代码,没有做任何优化。在调试代码时可以使用。
  d) 针对pentium pro优化:虽然该项不是本机代码中的缺省选项,但是我通常会使用该选项。该选项编译出的可执行程序在pentium pro和pentium 2以上的机器上可以运行得更快,而在比较老的机器上要稍稍慢一些。考虑到现在用pentium 2都是落伍,所以推荐大家使用该选项。
  e) 产生符号化调试信息:该项在编译过程中生成一些调试信息,使用户可以利用visual c++一类的工具来调试编译好的代码。使用该选项会生成一个.pdf文件,该文件记录了可执行文件中的标志信息。当程序拥有api函数或dll调用时,该选项还是比较有帮助的。
  2. 高级优化
  高级优化中的设置可以帮助你提高软件的速度,但是有时候也会引入一些错误,因此我建议大家尽量小心地使用它们。如果在代码中有比较大的循环体或者复杂的数学运算时,选中高级优化中的某些项会大幅度提升代码的性能。如果你使用了高级优化功能,我建议你严格测试编译好的文件。
  a) 假定无别名:可以提高循环体中代码的执行效率,但是在如果通过变量的引用改变变量值的情况下,例如调用一个方法,变量的引用作为方法的参数,在方法中改变了变量的值的话,就会引发错误。有可能只是返回的结果错误,也有可能是导致程序中断运行的严重错误。
  b) 取消数组绑定检查、取消整数溢出检查和取消浮点错误检查:在程序运行时,如果通过这些检查发现了错误,错误处理代码会处理这些错误。但是如果取消了这些检查,发生了错误程序就无法处理。只有当你确定你的代码中不会出现上面的这些错误时,你才可以使用这些选项。它们将使软件的性能得到很大的提升。
  c) 允许不舍入的浮点操作:选择该选项可以是编译出来的程序更快地处理浮点操作。它唯一的缺点就是在比较两个浮点数时可能会导致不正确的结果。
  d) 取消pentium fdiv安全检查:该选项是针对一些老的pentium芯片设置的,现在看来已经过时了。



发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表