您的位置:寻梦网首页编程乐园VB 编程乐园VB 函数速查
Visual Basic 函数速查
运算符
& 算符
* 算符
+ 运算符
- 运算符
/ 运算符
\ 运算符
^运算符
= 操作符
AddressOf 运算符
And 运算符
比较运算符
Eqv 运算符
Imp 运算符
Is 运算符
Like 运算符
Mod 运算符
Not 运算符
Or 运算符
Xor 运算符

& 运算符

用来强制两个表达式作字符串连接。

语法

result = expression1 & expression2

& 运算符的语法具有以下几个部分:

部分 描述
result 必需的;任何String或Variant 变量。
expression1 必需的;任何表达式。
expression2 必需的;任何表达式。

说明

如果 expression 不是字符串,则将其转换成 String 变体。如果两个表达式都是字符串表达式,则 result 的数据类型是 String;否则 result String 变体。如果两个表达式都是 Null,则 result 也是 Null。但是,只要有一个 expression Null,那么在与其它表达式连接时,都将其作为长度为零的字符串 ("") 处理。任何 Empty 类型表达式也作为长度为零的字符串处理。


* 运算符

用来将两数相乘。

语法

result = number1*number2

* 运算符的语法具有以下几个部分:

部分 描述
result 必需的;任何数值变量。
number1 必需的;任何数值表达式。
number2 必需的;任何数值表达式。

说明

result 的数据类型通常与最精确的表达式的数据类型相同。精确度由最低到最高的顺序是

Byte、Integer、Long、Single、Currency、Double和Decimal。下列情况是例外:

如果 result
乘法运算有一个 Single 和一个Long 转换成 Double
result 的数据类型是 LongSingle Date 变体且超出正确范围, 转换成有 Double Variant
result 的数据类型是 Byte 变体,且超出正确范围, 转换成 Integer 变体。
result 的数据类型是 Integer 变体,且超出正确范围, 转换成 Long 变体。

如果有一个或两个表达式是 Null 表达式,则 result Null。如果一个表达式是 Empty,则作为 0 处理。

注意 乘法用到的精确度等级与加法和减法用到的精确度等级不一样。


+ 运算符

用来求两数之和。

语法

result = expression1+expression2

+ 运算符的语法具有以下几个部分:

部分 描述
result 必需的;任何数值变量。
expression1 必需的;任何表达式。
expression2 必需的;任何表达式。

说明

在使用 + 运算符时有可能无法确定是做加法还是做字符串连接。为避免混淆,请使用 & 运算符进行连接,并且改进程序代码的可读性。

如果至少有一个表达式不是 Variant,则可运用以下法则:

如果
两个表达式都是数值数据类型 (Byte、Boolean、Integer、Long、Single、Double、Date、Currency 或是 Decimal) 相加。
两个表达式都是 String 连接。
一个表达式是数值数据类型而另一个是 Null 之外的任意 Variant 相加。
一个表达式是 String 而其它是 Null 之外的任意 Variant 连接。
一个表达式是 Empty Variant 返回另一个不变的表达式作为 result
一个表达式是数值数据类型,而另一个是 String 产生一个类型不匹配错误。
每个表达式都是 Null result Null

如果两个表达式都是 Variant 表达式,则可运用下列规则:

如果
两个 Variant 表达式都是数值 相加。
两个 Variant 表达式都是字符串 连接。
一个 Variant 表达式是数值而另一个是字符串 相加。

对于只有数值数据类型表达式的单纯加法,result 的数据类型通常与其中最精确的表达式的数据类型相同。精确度由最低到最高的顺序是 ByteIntegerLongSingleDoubleCurrency Decimal。但下列情况例外:

如果 result
一个 Single 和一个 Long 相加, 一个 Double
result 的数据类型是 LongSingle Date 变体,且越出正确范围, 转换成 Double 变体。
result 的数据类型是 Byte 变体,且超过本身的正确范围时, 转换成 Integer 变体。
result 的数据类型是 Integer 变体,且超过本身的正确范围时, 转换成 Long 变体。
将一个 Date 加到任何数据类型上, 一个 Date

如果有一个或两个表达式是 Null 表达式,则 result Null。如果两个表达式都是 Empty,则 result Integer。但是,如果只有一个表达式是 Empty,则另一个表达式原封不动地作为 result 返回。

注意 加法和减法用到的精确度等级与乘法用到的精确度等级不一样。


- 运算符

用来求两数之差或表示数值表达式的负值。

语法 1

result = number1 - number2

语法 2

- number

- 运算符的语法具有以下几个部分:

部分 描述
result 必需的;任何数值变量。
number 必需的;任何数值表达式。
number1 必需的;任何数值表达式。
number2 必需的;任何数值表达式。

说明

在语法 1 中,- 运算符是求两数之差的算术减法运算符。在语法 2 中,- 运算符为一元负运算符,说明表达式的值为负值。

result 的数据类型通常与最精确的表达式的数据类型相同。精确度由最低到最高的顺序是Byte、Integer、Long、Single、Double、Currency 和 Decimal。

下列情况例外:

如果 result
当减法运算中有一个 Single 和一个 Long 转换成一个 Double
result 的数据类型是一个 LongSingle 或 Date 变体,且超出正确范围, 转换成包含 Double 的Variant。
result 的数据类型是一个 Byte 变体,且超出正确范围, 转换成一个 Integer 变体。
result 的数据类型是一个 Integer 变体,且超出正确范围, 转换成一个 Long 变体。
减法运算中有 Date 和其它任何数据类型, 一个 Date
减法运算中有两个 Date 表达式, 一个 Double

如果有一个或两个表达式是 Null 表达式,则 result Null。如果一个表达式是 Empty,则作为 0 处理。

注意 加法和减法用到的精确度等级与乘法用到的精确度等级不一样。


/ 运算符

用来进行两个数的除法运算并返回一个浮点数。

语法

result = number1/number2

/ 运算符的语法具有以下几个部分:

部分 描述
result 必需的;任何数值变量。
number1 必需的;任何数值表达式。
number2 必需的;任何数值表达式。

说明

result 的数据类型通常是 Double 或 Double 变体。下列情况是例外:

如果 result
两个表达式都是 Byte、Integer 或Single表达式时, 一个 Single,除非超出正确范围;如果发生这种情况,则产生错误。
两个表达式都是 ByteInteger Single 变体, 一个 Single 变体,除非已超出正确范围;一旦发生这种情况,result 是一个包含 Double 的 Variant。
除法运算中有一个 Decimal及其它任何数据类型, 一个 Decimal 数据类型。

如果有一个或是两个表达式是 Null 表达式,则 result Null。如果一个表达式是 Empty 则作为 0 处理。


\ 运算符

用来对两个数作除法并返回一个整数。

语法

result = number1\number2

\ 运算符的语法具有以下几个部分:

部分 描述
result 必需的;任何数值变量。
number1 必需的;任何数值表达式。
number2 必需的;任何数值表达式。

说明

在进行除法运算之前,数值表达式通过舍去小数部分转换成 Byte、Integer 或 Long表达式。

通常,无论 result 是不是整数,result 的数据类型都是 ByteByte 变体、IntegerInteger 变体、LongLong 变体。任何小数部分都被删除。但是,如果任何一个表达式是 Null,则 result Null。如果一个表达式是 Empty,则作为0 处理。


^运算符

用来求一个数字的某次方,次方数为 exponent 值。

语法

result = number^exponent

^ 运算符的语法具有以下几个部分:

部分 描述
result 必需的;任何数值变量。
number 必需的;任何数值表达式。
exponent 必需的;任何数值表达式。

说明

只有当 exponent 为整数值时,number 才可以为负数。在表达式中执行多个指数运算时,^ 运算符的计算顺序从左到右。

result 的数据类型通常是 Double 或包含 Double 的 Variant。但是,如果 number exponent 中有一个是 Null 表达式,则 result 也是 Null


= 操作符

描述

用于对一个变量或属性赋值。

语法

variable = value

= 操作符语法有如下几部分:

部分 描述
variable 任何变量或任何可写的属性。
value 任何数值型或字符串文字、常数或表达式。

说明

等号左边的名字可以是一个简单的标量变量或一个数组的元素。等号左边的属性只能是运行时可写的属性。


AddressOf 运算符

一个一元运算符,它将其后面的过程的地址传递给一个 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 语句放置于回调过程的起始处来达到这个要求。


And 运算符

用来对两个表达式进行逻辑连接。

语法

result = expression1 And expression2

And 运算符的语法具有以下几个部分:

部分 描述
result 必需的;任何数值变量。
expression1 必需的;任何表达式。
expression2 必需的;任何表达式。

说明

如果两个表达式的值都是 True,则 resultTrue。如果其中一个表达式的值是 False,则 resultFalse。下列表格说明如何确定 result

如果 expression1 expression2 result
True True True
True False False
True Null Null
False True False
False False False
False Null False
Null True Null
Null False False
Null Null Null

And 运算符还对两个数值表达式中位置相同的位进行逐位比较,并根据下表对 result 中相应的位进行设置:

如果在 expression1 的位为 且在 expression2 中的位为 result
0 0 0
0 1 0
1 0 0
1 1 1


比较运算符

用来比较表达式。

语法

result = expression1 comparisonoperator expression2

result = object1 Is object2

result = string Like pattern

比较运算符具有以下几个部分:

部分 描述
result 必需的;任何数值变量。
expression 必需的;任何表达式。
comparisonoperator 必需的;任何比较运算符。
object 必需的;任何对象名称。
string 必需的;任何字符串表达式。
pattern 必需的;任何字符串表达式或字符的范围。

说明

下列表格中有一系列比较运算符以及判定 result TrueFalse 还是 Null 的条件:

运算符 True if False if Null if
<(小于) expression1 < expression2 expression1 >= expression2 expression1 or expression2 = Null
<=(小于或等于) expression1 <= expression2 expression1 > expression2 expression1 or expression2 = Null
>(大于) expression1 > expression2 expression1 <= expression2 expression1 or expression2 = Null
>=(大于或等于) expression1 >= expression2 expression1 < expression2 expression1 or expression2 = Null
=(等于) expression1 = expression2 expression1 <> expression2 expression1 or expression2 = Null
<>(不等于) expression1 <> expression2 expression1 = expression2 expression1 or expression2 = Null

注意 Is Like 运算符有特定的比较功能,它们不同於表格中的运算符。

在比较两个表达式的时候可能难以确定将要比较的表达式是数字还是字符串。下列表格将说明如何比较表达式,或说明当其中一个表达式不是 Variant 时,如何获得比较的结果。

如果
两个表达式都是数值数据类型 (Byte、Boolean、Integer、Long、Single、Double、Date、Currency 或Decimal) 进行数值比较。
两个表达式都是 String 进行字符串比较
一个表达式是数值数据类型而另一个是数字 Variant、或可以为一数字 进行数值比较。
一个表达式是数值数据类型而另一个是不能转换成数字的字符串 Variant 产生类型不匹配的错误。
一个表达式是 String,而另一个是除了 Null 以外的任何 Variant 进行字符串比较。
一个表达式是 Empty 而另一个是数值数据类型 进行数值比较,使用 0 作为 Empty 表达式。
一个表达式是 Empty 而另一个是 String 进行字符串比较,使用长度为零的字符串 ("") 作为 Empty 表达式。

如果 expression1 expression2 都是 Variant 表达式, 则它们的基本类型决定了比较方式。下列表格说明如何比较表达式,或指出通过比较得到的结果,此结果取决于 Variant 的基本类型:

如果
两个 Variant 表达式都是数值 进行数值比较。
两个 Variant 表达式都是字符串 进行字符串比较。
一个 Variant 表达式是数值而另一个是字符串 数值表达式小于字符串表达式。
一个 Variant 表达式是 Empty 而另一个是数值 进行数值比较,使用 0 作为 Empty 表达式。
一个 Variant 表达式是 Empty 而另一个是字符串 进行字符串比较,使用长度为零的字符串 ("") 作为 Empty 表达式。
两个 Variant 表达式都是 Empty 表达式相等。

当一个 Single 与一个 Double 作比较时,Double 会进行舍入处理而与此 Single 有相同的精确度。

如果一个 Currency 与一个 Single Double 进行比较,则 SingleDouble 转换成一个 Currency。与此相似,当一个 Decimal 要与一个 SingleDouble 进行比较时,SingleDouble 会转换成一个 Decimal。对于 Currency,任何小于 .0001 的小数将被舍弃,对于 Decimal,任何小于 1E-28 的小数将被舍弃,或者可能产生溢出错误。舍弃这样的小数部分会使原来不相等的两个数值经过比较后相等。


Eqv 运算符

用来对两个表达式进行逻辑等价运算。

语法

result = expression1 Eqv expression2

Eqv 运算符的语法具有以下几个部分:

部分 描述
result 必需的;任何数值变量。
expression1 必需的;任何表达式。
expression2 必需的;任何表达式。

说明

如果有一个表达式是 Null,则 result 也是 Null。如果表达式都不是 Null,则根据下表来确定 result

如果 expression1 expression2 result
True True True
True False False
False True False
False False True

Eqv 运算符对两个数值表达式中位置相同的位进行逐位比较,并根据下表对 result 中相应的位进行设置:

如果在 expression1 的位为 且在 expression2 中的位为 result
0 0 1
0 1 0
1 0 0
1 1 1


Imp 运算符

用来对两个表达式进行逻辑蕴涵运算。

语法

result = expression1 Imp expression2

Imp 运算符的语法具有以下几个部分:

部分 描述
result 必需的;任何数值变量。
expression1 必需的;任何表达式。
expression2 必需的;任何表达式。

说明

下列表格说明如何确定 result

如果 expression1 expression2 result
True True True
True False False
True Null Null
False True True
False False True
False Null True
Null True True
Null False Null
Null Null Null

Imp 运算符对两个数值表达式中位置相同的位进行逐位比较,并根据下表对 result 中相应的位进行设置:

如果在 expression1 的位为 且在 expression2 中的位为 result
0 0 1
0 1 1
1 0 0
1 1 1


Is 运算符

用来比较两个对象的引用变量。

语法

result = object1 Is object2

Is 运算符的语法具有以下几个部分:

部分 描述
result 必需的;任何数值变量。
object1 必需的;任何对象名称。
object2 必需的;任何对象名称。

说明

如果 object1object2 两者引用相同的对象,则 resultTrue;否则,resultFalse。有很多方法使两个变量引用相同的对象。

在以下示例中,A 和 B 已被设置成与 C 引用相同的对象:

Set A = B

在下例中,A 和 B 引用的对象与 C 相同:

Set A = C
Set B = C

Like 运算符

用来比较两个字符串。

语法

result = string Like pattern

Like 运算符的语法具有以下几个部分:

部分 描述
result 必需的;任何数值变量。
string 必需的;任何字符串表达式。
pattern 必需的;任何字符串表达式,遵循“说明”中的模式匹配约定。

说明

如果 string pattern 匹配,则 resultTrue;如果不匹配,则 resultFalse。但是如果 stringpattern 中有一个为 Null,则 resultNull

Like 运算符的特性随着 Option Compare 语句而不同。每个模块的缺省字符串比较方法是 Option Compare Binary

在字符串比较中,Option Compare Binary 的结果是根据字符的内部二进制表示法导出的排序顺序得到的。在 Microsoft Windows 中,排序顺序由代码页决定。下例说明通常二进制的排序顺序:

A < B < E < Z < a < b < e < z < _ < _ < _ < _ < _ <


Mod 运算符

用来对两个数作除法并且只返回余数。

语法

result = number1 Mod number2

Mod 的语法具有以下几个部分:

部分 描述
result 必需的;任何数值变量。
number1 必需的;任何数值表达式。
number2 必需的;任何数值表达式。

说明

在进行 Mod 运算或求余数运算时,该运算符将 number1 number2 除(将浮点数字四舍五入成整数),并把余数作为 result 的值返回。例如,在下列表达式中,A (result) 等于 5。

A = 19 Mod 6.7

一般说来,不管 result 是否为一个整数,result 的数据类型为 Byte,Byte 变体、Integer、Integer 变体、Long 或一个包含 Long 的Variant。任何小数部分都被删除。但是,如果任何一个 Null,类型的表达式出现时,result 都将是 Null。任何 Empty 类型表达式都作为 0 处理。


Not 运算符

用来对表达式进行逻辑否定运算。

语法

result = Not expression

Not 运算符的语法具有以下几个部分:

部分 描述
result 必需的;任何数值变量。
expression 必需的;任何表达式。

说明

下表说明如何确定 result

如果 expression result
True False
False True
Null Null

此外,Not 运算符改变任何变量的位值,并根据下表设置 result 中相应的位:

如果在 expression 的位为 则在 result 中的位为
0 1
1 0


Or 运算符

用来对两个表达式进行逻辑析取运算。

语法

result = expression1 Or expression2

Or 运算符的语法具有以下几个部分:

部分 描述
result 必需的;任何数值变量。
expression1 必需的;任何表达式。
expression2 必需的;任何表达式。

说明

如果两个表达式中至少有一个为 True,则 result True。下列表格说明如何确定 result

如果 expression1 expression2 result
True True True
True False True
True Null True
False True True
False False False
False Null Null
Null True True
Null False Null
Null Null Null

Or 运算符也对两个数值表达式中位置相同的位进行逐位比较,并根据下表对 result 中相应的位进行设置:

如果在 expression1 的位为 且在 expression2 中的位为 result
0 0 0
0 1 1
1 0 1
1 1 1


Xor 运算符

用来对两个表达式进行逻辑互斥或运算。

语法

[result =] expression1 Xor expression2

Xor 运算符的语法具有以下几个部分:

部分 描述
result 可选;任何数值变量。
expression1 必需的;任何表达式。
expression2 必需的;任何表达式。

说明

如果表达式中有一个而且只有一个值为 True,则 resultTrue。但是,如果表达式中有一个为 Null,则 result 也为 Null。当两个表达式都不为 Null,则根据下表来确定 result

如果 expression1 expression2 result
True True False
True False True
False True True
False False False

Xor 运算符既可作为逻辑运算符,也可作为位运算符。使用互斥或的逻辑进行的两个表达式的逐位比较,其结果通过下表说明:

如果 expression1 expression2 result
0 0 0
0 1 1
1 0 1
1 1 0