ByVal和ByRef(编写ASP子程序所用到命令)
程序员文章站
2022-07-02 08:36:22
byval 传送参数内存的一个拷贝给被调用者。也就是说,栈中压入的直接就是所传的值。 byref 传送参数内存的实际地址给被调用者。也就是说,栈中压入的...
byval 传送参数内存的一个拷贝给被调用者。也就是说,栈中压入的直接就是所传的值。
byref 传送参数内存的实际地址给被调用者。也就是说,栈中压入的是实际内容的地址。被调用者可以直接更改该地址中的内容。
byval是传递值 源数据不会被修改
你可以把这个值当作自己的局部变量来使用
byref是传递地址 , 源数据可能被修改
你对这个变量的操作将对你传入的那个变量产生影响,就像指针的感觉
实例:
sub add1(byval no as int32)
no=no+100
end sub
sub add2(byref no as int32)
no=no+100
end sub
private sub button1_click(sender as object,e as eventargs)handles button1.click
dim a as int32
a=100
add1(a)
msgbox ("a的值为:" & a) '显示:a的值为100
add2(a)
msgbox ("a的值为:" & a) '显示:a的值为200,因为add2中的参数no为byref,即
'按地址传递,因此在add2中对no进行修改后,将会导致
'源参数a的值也被修改。
end sub
——————————————————————————————————————
3、byval和byref
byval传递的参数值,而byref传递的参数的地址。在这里,我们不用去区别传指针/传地址/传引用的不同,在vb里,它们根本就是一个东西的三种不同说法,即使vb的文档里也有地方在混用这些术语(但在c++里的确要区分指针和引用)
初次接触上面的程序二swapptr的朋友,一定要搞清在里面的copymemory调用中,在什么地方要加byval,什么地方不加(不加byval就是使用vb缺省的byref)
准确的理解传值和传地址(指针)的区别,是在vb里正确使用指针的基础。
现在一个最简单的实验来看这个问题,如下面的程序三:
【程序三】:体会byval和byref
sub testcopymemory()
dim k as long
k = 5
note: copymemory byval varptr(k), 40000, 4
debug.print k
end sub
上面标号note处的语句的目的,是将k赋值为40000,等同于语句k=40000,你可以在"立即"窗口试验一下,会发现k的值的确成了40000。
实际上上面这个语句,翻译成白话:
-----------------------------------------------------------------
就是从保存常数40000的临时变量处拷贝4个字节到变量k所在的内存中。
-----------------------------------------------------------------
现在我们来改变一个note处的语句,若改成下面的语句:
note2: copymemory byval varptr(k), byval 40000, 4
这句话的意思就成了,从地址40000拷贝4个字节到变量k所在的内存中。由于地址40000所在的内存我们无权访问,操作系统会给我们一个access violation内存越权访问错误,告诉我们"试图读取位置0x00009c40处内存时出错,该内存不能为'read'"。
我们再改成如下的语句看看。
note3: copymemory varptr(k), 40000, 4
这句话的意思就成了,从保存常数40000的临时变量处拷贝4个字节到到保存变量k所在内存地址值的临时变量处。这不会出出内存越权访问错误,但k的值并没有变。
我们可以把程序改改以更清楚的休现这种区别,如下面的程序四:
【程序四】:'看看我们的东西被拷贝到哪儿去了
sub testcopymemory()
dim i as long, k as long
k = 5
i = varptr(k)
note4: copymemory i, 40000, 4
debug.print k
debug.print i
i = varptr(k)
note5: copymemory byval i, 40000, 4
debug.print k
end sub
程序输出:
5
40000
40000
由于note4处使用缺省的byref,传递的是i的地址(也就是指向i的指针),所以常量40000拷贝到了变量i里,因此i的值成了40000,而k的值却没有变化。但是,在note4前有:i=varptr(k),本意是要把i本身做为一个指针来使用。这时,我们必须如note5那样用byval来传递指针i,由于i是指向变量k的指针,所以最后常量40000被
byref 传送参数内存的实际地址给被调用者。也就是说,栈中压入的是实际内容的地址。被调用者可以直接更改该地址中的内容。
byval是传递值 源数据不会被修改
你可以把这个值当作自己的局部变量来使用
byref是传递地址 , 源数据可能被修改
你对这个变量的操作将对你传入的那个变量产生影响,就像指针的感觉
实例:
复制代码 代码如下:
sub add1(byval no as int32)
no=no+100
end sub
sub add2(byref no as int32)
no=no+100
end sub
private sub button1_click(sender as object,e as eventargs)handles button1.click
dim a as int32
a=100
add1(a)
msgbox ("a的值为:" & a) '显示:a的值为100
add2(a)
msgbox ("a的值为:" & a) '显示:a的值为200,因为add2中的参数no为byref,即
'按地址传递,因此在add2中对no进行修改后,将会导致
'源参数a的值也被修改。
end sub
——————————————————————————————————————
3、byval和byref
byval传递的参数值,而byref传递的参数的地址。在这里,我们不用去区别传指针/传地址/传引用的不同,在vb里,它们根本就是一个东西的三种不同说法,即使vb的文档里也有地方在混用这些术语(但在c++里的确要区分指针和引用)
初次接触上面的程序二swapptr的朋友,一定要搞清在里面的copymemory调用中,在什么地方要加byval,什么地方不加(不加byval就是使用vb缺省的byref)
准确的理解传值和传地址(指针)的区别,是在vb里正确使用指针的基础。
现在一个最简单的实验来看这个问题,如下面的程序三:
【程序三】:体会byval和byref
复制代码 代码如下:
sub testcopymemory()
dim k as long
k = 5
note: copymemory byval varptr(k), 40000, 4
debug.print k
end sub
上面标号note处的语句的目的,是将k赋值为40000,等同于语句k=40000,你可以在"立即"窗口试验一下,会发现k的值的确成了40000。
实际上上面这个语句,翻译成白话:
-----------------------------------------------------------------
就是从保存常数40000的临时变量处拷贝4个字节到变量k所在的内存中。
-----------------------------------------------------------------
现在我们来改变一个note处的语句,若改成下面的语句:
note2: copymemory byval varptr(k), byval 40000, 4
这句话的意思就成了,从地址40000拷贝4个字节到变量k所在的内存中。由于地址40000所在的内存我们无权访问,操作系统会给我们一个access violation内存越权访问错误,告诉我们"试图读取位置0x00009c40处内存时出错,该内存不能为'read'"。
我们再改成如下的语句看看。
note3: copymemory varptr(k), 40000, 4
这句话的意思就成了,从保存常数40000的临时变量处拷贝4个字节到到保存变量k所在内存地址值的临时变量处。这不会出出内存越权访问错误,但k的值并没有变。
我们可以把程序改改以更清楚的休现这种区别,如下面的程序四:
【程序四】:'看看我们的东西被拷贝到哪儿去了
复制代码 代码如下:
sub testcopymemory()
dim i as long, k as long
k = 5
i = varptr(k)
note4: copymemory i, 40000, 4
debug.print k
debug.print i
i = varptr(k)
note5: copymemory byval i, 40000, 4
debug.print k
end sub
程序输出:
5
40000
40000
由于note4处使用缺省的byref,传递的是i的地址(也就是指向i的指针),所以常量40000拷贝到了变量i里,因此i的值成了40000,而k的值却没有变化。但是,在note4前有:i=varptr(k),本意是要把i本身做为一个指针来使用。这时,我们必须如note5那样用byval来传递指针i,由于i是指向变量k的指针,所以最后常量40000被
上一篇: 中山美食排行榜
下一篇: 什么花椒最好,花椒有哪些种类