1. 假设
vb中有如下的变量声明:
dim s1, s2 as string
则s1是一个variant型变量,而s2是一个string型变量
如果想要声明两个string变量s1和s2
应该用:
dim s1 as string, s2 as string
2. VB中的对象是自动回收的,类似java
在一个过程中
sub Foo()
dim obj as new Object
. ''do something with obj
end sub
过程结束的时候没有必要 set obj = nothing
因为当离开该过程的时候,局部变量obj消失,因此对Object对象实例的引用也就消失(除非在过程内部有其他的全局变量引用了该对象的实例),所以对象实例会自动释放
但是对于模块级的对象变量,new了一个实例后用完了必须set obj = nothing来释放该实例
3. 对对象变量赋值应该用 set obj = AnOtherObj 这种方式,相当于让obj指向AnOtherObj所指向的对象。VB中的对象变量实质上是一个指向对象实例的指针,这点和java,pascal相同,和C++中不同
4. VB中字符串的内部存储格式是Unicode,它可以自动转化为ANSI字符(单字节字符)或者 DBCS 字符(双字节字符)。例如
dim s1 as string, s2 as string
s1 = "中文"
s2 = left(s1, 1)
则得到的实际上是 s2 = "中"
因为VB会自动将s1内部unicode的"中"字单作一个DBCS字符取出来传给s2
因此处理双字节字符的时候特别要注意,很容易产生数组溢出错误
VB中的常用字符串处理函数,例如Asc, Left, Mid都会自动判断处理的字符串中的每个字符是单字节还是双字节(因为字符串在内部以Unicode存储,所以这一点很容易做到),然后自动转化为ANSI字符或DBCS字符。
5. 字符串的比较应该是用 strCmp 函数,而不是简单的用 = 号
StrComp(string1, string2[, compare])
其中参数compare的取值含义如下:
常量 值 含义
vbUseCompareOption -1 根据Option Compare 语句的设定进行字符串比较
vbBinaryCompare 0 进行二进制比较,也就是将string1和string2中的unicode字符看作数组进行字典序比较
vbTextCompare 1 进行文本比较
vbDatabaseCompare 2 这个选项只适用于Microsoft Access,根据数据库的设定进行比较
对于英文字符串进行 vbTextCompare 比较时,不区分字母大小写,例如: "a" 与 "A" 相等;
对于中文或其他双字节字符串进行 vbTextCompare 比较时,不区分全角字符和半角字符,例如 "A", "A", "a", "a" 都相等;
6. VB中字符串处理的函数有三种版本:
(1) ANSI和DBCS版本,一般的字符串函数(例如Mid(), Left(), )都是该版本,该版本的函数可以自动识别ANSI字符和DBCS字符,而且无论是ANSI字符还是DBCS字符都当作一个字符处理(虽然一个DBCS字符是两个字节,但还是当作一个字符处理)
(2) 二进制版本,这个版本的函数是在第一类函数的名称后面加上B, 例如 MidB(), LeftB()……;这个版本的函数将字符串当作字节数组处理,例如 s = "abc", k = LenB(s) , 则 k=6,因为字符串在VB内部以unicode存储,而一个u