|
Visual Basic 函数速查
运算符
用来强制两个表达式作字符串连接。 语法 result = expression1 & expression2 & 运算符的语法具有以下几个部分:
说明 如果 expression 不是字符串,则将其转换成 String 变体。如果两个表达式都是字符串表达式,则 result 的数据类型是 String;否则 result 是 String 变体。如果两个表达式都是 Null,则 result 也是 Null。但是,只要有一个 expression 是 Null,那么在与其它表达式连接时,都将其作为长度为零的字符串 ("") 处理。任何 Empty 类型表达式也作为长度为零的字符串处理。 用来将两数相乘。 语法 result = number1*number2 * 运算符的语法具有以下几个部分:
说明 result 的数据类型通常与最精确的表达式的数据类型相同。精确度由最低到最高的顺序是 Byte、Integer、Long、Single、Currency、Double和Decimal。下列情况是例外:
如果有一个或两个表达式是 Null 表达式,则 result 为 Null。如果一个表达式是 Empty,则作为 0 处理。 注意 乘法用到的精确度等级与加法和减法用到的精确度等级不一样。 用来求两数之和。 语法 result = expression1+expression2 + 运算符的语法具有以下几个部分:
说明 在使用 + 运算符时有可能无法确定是做加法还是做字符串连接。为避免混淆,请使用 & 运算符进行连接,并且改进程序代码的可读性。 如果至少有一个表达式不是 Variant,则可运用以下法则:
如果两个表达式都是 Variant 表达式,则可运用下列规则:
对于只有数值数据类型表达式的单纯加法,result 的数据类型通常与其中最精确的表达式的数据类型相同。精确度由最低到最高的顺序是 Byte、Integer、Long、Single、Double、Currency 和 Decimal。但下列情况例外:
如果有一个或两个表达式是 Null 表达式,则 result 为 Null。如果两个表达式都是 Empty,则 result 是 Integer。但是,如果只有一个表达式是 Empty,则另一个表达式原封不动地作为 result 返回。 注意 加法和减法用到的精确度等级与乘法用到的精确度等级不一样。 用来求两数之差或表示数值表达式的负值。 语法 1 result = number1 - number2 语法 2 - number - 运算符的语法具有以下几个部分:
说明 在语法 1 中,- 运算符是求两数之差的算术减法运算符。在语法 2 中,- 运算符为一元负运算符,说明表达式的值为负值。 result 的数据类型通常与最精确的表达式的数据类型相同。精确度由最低到最高的顺序是Byte、Integer、Long、Single、Double、Currency 和 Decimal。 下列情况例外:
如果有一个或两个表达式是 Null 表达式,则 result 为 Null。如果一个表达式是 Empty,则作为 0 处理。 注意 加法和减法用到的精确度等级与乘法用到的精确度等级不一样。 用来进行两个数的除法运算并返回一个浮点数。 语法 result = number1/number2 / 运算符的语法具有以下几个部分:
说明 result 的数据类型通常是 Double 或 Double 变体。下列情况是例外:
如果有一个或是两个表达式是 Null 表达式,则 result 为 Null。如果一个表达式是 Empty 则作为 0 处理。 用来对两个数作除法并返回一个整数。 语法 result = number1\number2 \ 运算符的语法具有以下几个部分:
说明 在进行除法运算之前,数值表达式通过舍去小数部分转换成 Byte、Integer 或 Long表达式。 通常,无论 result 是不是整数,result 的数据类型都是 Byte、Byte 变体、Integer、Integer 变体、Long 或 Long 变体。任何小数部分都被删除。但是,如果任何一个表达式是 Null,则 result 为 Null。如果一个表达式是 Empty,则作为0 处理。 用来求一个数字的某次方,次方数为 exponent 值。 语法 result = number^exponent ^ 运算符的语法具有以下几个部分:
说明 只有当 exponent 为整数值时,number 才可以为负数。在表达式中执行多个指数运算时,^ 运算符的计算顺序从左到右。 result 的数据类型通常是 Double 或包含 Double 的 Variant。但是,如果 number 或 exponent 中有一个是 Null 表达式,则 result 也是 Null。 描述 用于对一个变量或属性赋值。 语法 variable = value = 操作符语法有如下几部分:
说明 等号左边的名字可以是一个简单的标量变量或一个数组的元素。等号左边的属性只能是运行时可写的属性。 一个一元运算符,它将其后面的过程的地址传递给一个 API 过程,该 API 过程在参数表对应位置中需要一个函数指针。 语法 AddressOf procedurename 必需的 procedurename 指定要传递的地址是哪一个过程的地址。这个过程必须是发出调用命令的工程中的一个标准模块模块里的一个过程。 说明 当一个过程的名称出现在一个参数列表中时,通常该过程已经被计算,并且该过程返回值的地址也会被传递。AddressOf 允许该过程的地址被传递给动态链接库 (DLL) 中的一个 Windows API 函数,而不是传递该过程的返回值。API 函数然后就可以使用这个地址来调用相应的 Basic 过程,这个过程就是我们所知道的回调。AddressOf 运算符只出现在对 API 过程的调用中。 尽管可以使用 AddressOf 运算符在 Basic 过程之间传递过程指针,却不能通过这样的一个指针从 Basic 内部调用一个函数。这就是说,例如,一个使用 Basic 编写的类 不能使用这样的一个指针来回调自己的控制器。当使用 AddressOf 运算符在 Basic 内的过程之间传递一个过程的指针时,被调用过程的参数类型必须定义为 As Long。 警告 如果不能完全理解函数回调的概念,则使用 AddressOf 运算符可能会导致意想不到的结果。必须理解回调的 Basic 部份是如何工作的,以及接受所传递的函数地址的 DLL 的代码是如何工作的。调试这样的交互操作是非常困难的,因为该程序和开发环境运行在相同的进程中。在某些情况下,系统的调试也许是不可能的。 注意 可以使用 Microsoft Visual C++ (或者类似的工具)编译的 DLLs 来创建自己的回调函数原型。要使用 AddressOf 运算符来工作,您的原型必需使用 __stdcall 调用约定。缺省的调用约定 (__cdecl) 不能与 AddressOf 运算符一起工作。 因为一个回调的调用程序不在用户自己的程序中,所以很重要的一点是要保证回调过程中的错误不被回传到调用者。可以通过把 On Error Resume Next 语句放置于回调过程的起始处来达到这个要求。 用来对两个表达式进行逻辑连接。 语法 result = expression1 And expression2 And 运算符的语法具有以下几个部分:
说明 如果两个表达式的值都是 True,则 result 是 True。如果其中一个表达式的值是 False,则 result 是 False。下列表格说明如何确定 result:
And 运算符还对两个数值表达式中位置相同的位进行逐位比较,并根据下表对 result 中相应的位进行设置:
用来比较表达式。 语法 result = expression1 comparisonoperator expression2 result = object1 Is object2 result = string Like pattern 比较运算符具有以下几个部分:
说明 下列表格中有一系列比较运算符以及判定 result 是 True、False 还是 Null 的条件:
注意 Is 和 Like 运算符有特定的比较功能,它们不同於表格中的运算符。 在比较两个表达式的时候可能难以确定将要比较的表达式是数字还是字符串。下列表格将说明如何比较表达式,或说明当其中一个表达式不是 Variant 时,如何获得比较的结果。
如果 expression1 和 expression2 都是 Variant 表达式, 则它们的基本类型决定了比较方式。下列表格说明如何比较表达式,或指出通过比较得到的结果,此结果取决于 Variant 的基本类型:
当一个 Single 与一个 Double 作比较时,Double 会进行舍入处理而与此 Single 有相同的精确度。 如果一个 Currency 与一个 Single 或 Double 进行比较,则 Single 或 Double 转换成一个 Currency。与此相似,当一个 Decimal 要与一个 Single 或 Double 进行比较时,Single 或 Double 会转换成一个 Decimal。对于 Currency,任何小于 .0001 的小数将被舍弃,对于 Decimal,任何小于 1E-28 的小数将被舍弃,或者可能产生溢出错误。舍弃这样的小数部分会使原来不相等的两个数值经过比较后相等。 用来对两个表达式进行逻辑等价运算。 语法 result = expression1 Eqv expression2 Eqv 运算符的语法具有以下几个部分:
说明 如果有一个表达式是 Null,则 result 也是 Null。如果表达式都不是 Null,则根据下表来确定 result:
Eqv 运算符对两个数值表达式中位置相同的位进行逐位比较,并根据下表对 result 中相应的位进行设置:
用来对两个表达式进行逻辑蕴涵运算。 语法 result = expression1 Imp expression2 Imp 运算符的语法具有以下几个部分:
说明 下列表格说明如何确定 result:
Imp 运算符对两个数值表达式中位置相同的位进行逐位比较,并根据下表对 result 中相应的位进行设置:
用来比较两个对象的引用变量。 语法 result = object1 Is object2 Is 运算符的语法具有以下几个部分:
说明 如果 object1 和 object2 两者引用相同的对象,则 result 为 True;否则,result 为 False。有很多方法使两个变量引用相同的对象。 在以下示例中,A 和 B 已被设置成与 C 引用相同的对象:
在下例中,A 和 B 引用的对象与 C 相同:
用来比较两个字符串。 语法 result = string Like pattern Like 运算符的语法具有以下几个部分:
说明 如果 string 与 pattern 匹配,则 result 为 True;如果不匹配,则 result 为 False。但是如果 string 或 pattern 中有一个为 Null,则 result 为 Null。 Like 运算符的特性随着 Option Compare 语句而不同。每个模块的缺省字符串比较方法是 Option Compare Binary。 在字符串比较中,Option Compare Binary 的结果是根据字符的内部二进制表示法导出的排序顺序得到的。在 Microsoft Windows 中,排序顺序由代码页决定。下例说明通常二进制的排序顺序: A < B < E < Z < a < b < e < z < _ < _ < _ < _ < _ < 用来对两个数作除法并且只返回余数。 语法 result = number1 Mod number2 Mod 的语法具有以下几个部分:
说明 在进行 Mod 运算或求余数运算时,该运算符将 number1 用 number2 除(将浮点数字四舍五入成整数),并把余数作为 result 的值返回。例如,在下列表达式中,A (result) 等于 5。
一般说来,不管 result 是否为一个整数,result 的数据类型为 Byte,Byte 变体、Integer、Integer 变体、Long 或一个包含 Long 的Variant。任何小数部分都被删除。但是,如果任何一个 Null,类型的表达式出现时,result 都将是 Null。任何 Empty 类型表达式都作为 0 处理。 用来对表达式进行逻辑否定运算。 语法 result = Not expression Not 运算符的语法具有以下几个部分:
说明 下表说明如何确定 result:
此外,Not 运算符改变任何变量的位值,并根据下表设置 result 中相应的位:
用来对两个表达式进行逻辑析取运算。 语法 result = expression1 Or expression2 Or 运算符的语法具有以下几个部分:
说明 如果两个表达式中至少有一个为 True,则 result 为 True。下列表格说明如何确定 result:
Or 运算符也对两个数值表达式中位置相同的位进行逐位比较,并根据下表对 result 中相应的位进行设置:
用来对两个表达式进行逻辑互斥或运算。 语法 [result =] expression1 Xor expression2 Xor 运算符的语法具有以下几个部分:
说明 如果表达式中有一个而且只有一个值为 True,则 result 为 True。但是,如果表达式中有一个为 Null,则 result 也为 Null。当两个表达式都不为 Null,则根据下表来确定 result:
Xor 运算符既可作为逻辑运算符,也可作为位运算符。使用互斥或的逻辑进行的两个表达式的逐位比较,其结果通过下表说明:
|