了解对象的类型 如果你想知道一个对象是否是特殊的类型,请编写下面的代码: If TypeOf obj Is ListItem Then ... 如果想得到对象类型的名字,使用: MsgBox "The item is a " & TypeName(obj) 控制长时间的循环 当程序陷入一个很长时间的循环中时,你就不可能点击任何一个命令按钮或者按键。这样对于用户来说,就很不好控制。或许用户不想再执行循环,通过点击Cancel按钮退出呢?怎么解决这个问题?答案是:使用DoEvents命令!就是说,在循环的开始执行DoEvents命令,就象下面的代码一样: Dim i As Long For i = 1 To 1000000 DoEvents ... Next i 实际上,DoEvents命令并不需要放置在第1行,将它放在循环中的任何地方都可以。这样做后,程序的其他部分,比如一个结束循环的命令按钮,就又机会接受点击事件了。 使长循环运行更快 我发现,一般情况下,使用API函数GetInputState来检查程序输入队列的数值是较好的。我不知道为什么If语句提高了代码运行速度,但实际上确实是工作得很好。 因此,可以将下面的代码行 DoEvents 替换为 If GetInputState() Then DoEvents 试一试吧! 其实,这里面的原因在于:DoEvents语句允许任何应用程序执行相关事件,而不仅仅是你自己的程序。加入了GetInputState的判断后,就只接受你自己的程序的事件动作了! 让Select Case更简单 让我们看看下面的例子:通过用户点击不同组合的标签,建立一个字符串: lbl(0) = "Hello " lbl(1) = " I注释:m " lbl(2) = " Happy" lbl(3) = " Sad" ... sub lbl_click (index as integer) string$ = string$+lbl(index).caption 然后,你就必须要编写一系列的select case语句来分析这个字符串 ... select case string$ case "Hello I注释:m Happy" do something case "Hello I注释:m" this would be an error... case else do something else end select 可以看出,这将非常得复杂,特别是又许多标签而且需要合并操作的合法检查时。 为了解决这个难题,我创建了一个数组,它与标签的数目等长: arraylbl(n) as integer 数组起始数值为1,然后每个项目的值等于前一个的值乘以2(value*2),就象这样:1 2 4 8 16 32 64 ... 这样,每一对标签的组合都会又一个唯一的数值“ lbl(0) + lbl(1) = 1 + 2 = 3 lbl(0) + lbl(1) + lbl(4) = 1 + 2 + 16 = 19 现在,当点击一个标签时,将它对应的lblarray()数值添加进变量中。这样,基于几个数字,就可以简单地编写select case语句了: select case IsLegal case 3 注释: the string was valid call goodstuff case 19 注释:the string was valid call goodstuff case else 注释:invalid call nogood end select 呵呵,有时候,将字符进行数字化,能起到意想不到的好效果!