Office中國(guó)論壇/Access中國(guó)論壇

 找回密碼
 注冊(cè)

QQ登錄

只需一步,快速開(kāi)始

1234567下一頁(yè)
返回列表 發(fā)新帖
查看: 34002|回復(fù): 64
打印 上一主題 下一主題

[模塊/函數(shù)] 【新手入門(mén)】之五:公共變量與傳址過(guò)程、傳值過(guò)程

[復(fù)制鏈接]
跳轉(zhuǎn)到指定樓層
1#
發(fā)表于 2012-9-23 02:29:09 | 只看該作者 回帖獎(jiǎng)勵(lì) |倒序?yàn)g覽 |閱讀模式
在百度里見(jiàn)到一道很有意思的編程題,先貼上兩段代碼代碼給大家練練:
第一段代碼:返回值是什么?

  1. Dim a As Integer
  2. Sub test()
  3.     Dim b As Integer
  4.     a = 1
  5.     b = 2
  6.     Debug.Print fun1(fun1(a, b), b)
  7.     Debug.Print a
  8.     Debug.Print b
  9. End Sub
  10. Function fun1(x As Integer, y As Integer) As Integer
  11.     Dim i As Integer
  12.     For i = 1 To y
  13.         y = y + 1
  14.         x = x + 1
  15.         a = x + y
  16.     Next i
  17.     fun1 = a + y
  18. End Function
復(fù)制代碼
游客,如果您要查看本帖隱藏內(nèi)容請(qǐng)回復(fù)

第二段代碼:和上面的代碼相比,只是加了“ByVal”關(guān)鍵字,返回結(jié)果還是一樣嗎?

  1. Dim a As Integer
  2. Sub test()
  3.     Dim b As Integer
  4.     a = 1
  5.     b = 2
  6.     Debug.Print fun1(fun1(a, b), b)
  7.     Debug.Print a
  8.     Debug.Print b
  9. End Sub
  10. Function fun1(ByVal x As Integer, ByVal y As Integer) As Integer
  11.     Dim i As Integer
  12.     For i = 1 To y
  13.         y = y + 1
  14.         x = x + 1
  15.         a = x + y
  16.     Next i
  17.     fun1 = a + y
  18. End Function
復(fù)制代碼
游客,如果您要查看本帖隱藏內(nèi)容請(qǐng)回復(fù)


公共變量的影響:
問(wèn)題3:對(duì)第一段代碼刪除 Dim a As Integer,并把參數(shù)(x As Integer, y As Integer)改為:(x,y)【注】會(huì)有怎樣的結(jié)果呢?
問(wèn)題4:對(duì)于第二段代碼同樣刪除這句公共變量,又會(huì)有怎樣的結(jié)果呢?

答案嘛,大家可以在模塊的立即窗口(Ctrl+G)中得到,實(shí)在不清楚的再問(wèn)我。為什么會(huì)這樣。由于時(shí)間關(guān)系,我得稍后一些時(shí)間才能回復(fù)了,先占個(gè)樓層。
【注:由于刪除公共變量,x,y均為缺省變量類(lèi)型Variant。如果仍保留子函數(shù)中的Integer類(lèi)型,則會(huì)在傳址過(guò)程中出現(xiàn)變量不匹配的編譯錯(cuò)誤,因而需要改為(x,y)】
【新手入門(mén)】之一:If分支語(yǔ)句
【新手入門(mén)】之二:分支語(yǔ)句總結(jié)
【新手入門(mén)】之三:循環(huán)語(yǔ)句For
【新手入門(mén)】之四:循環(huán)語(yǔ)句Do和死循環(huán)
【新手入門(mén)】之五:公共變量與傳址過(guò)程、傳值過(guò)程
【新手入門(mén)】之六:“悲歡離合總無(wú)情”——淺談Split和Join
【新手入門(mén)】之七:嵌套與并列——再談If流程問(wèn)題
【新手入門(mén)】之八:“連就連”——淺談“&”和“+”連接符的區(qū)別

【新手入門(mén)】之九:從百錢(qián)百雞談起——淺談“規(guī)劃求解”兼答lingjiang問(wèn)
【新手入門(mén)】之十:書(shū)到用時(shí)方恨少——自定義菜單(Access 2003)的制作
【新手入門(mén)】之十一:淺談ADO之序言
【新手入門(mén)】之十二:淺談ADO之Connection
【新手入門(mén)】之十三:淺談ADO之Conmmand(上)
【新手入門(mén)】之十四:淺談ADO之Command(下)
【新手入門(mén)】之十五:淺談ADO之Recordset(上)
【新手入門(mén)】之十六:淺談ADO之Recordset(下)
【新手入門(mén)】之十七:淺談列表框的使用
【新手入門(mén)】之十八:雙擊列表框修改數(shù)據(jù)
【新手入門(mén)】之十九:從“書(shū)與女友恕不外借”談起——淺談“Bookmark”的使用
【新手入門(mén)】之二十:“書(shū)與書(shū)簽”——bookmark屬性答疑
【新手入門(mén)】之二十一:記錄集的“凌遲”——逐條導(dǎo)出記錄集

【新手進(jìn)階】之一:基礎(chǔ)算法(一)
【新手進(jìn)階】之二:基礎(chǔ)算法(二)
【新手進(jìn)階】之三:基礎(chǔ)算法(三)
【新手進(jìn)階】之四:基礎(chǔ)算法(四)
【新手進(jìn)階】之五:排序搜索(一)
【新手進(jìn)階】之六:排序搜索(二)
【新手進(jìn)階】之七:遞歸算法
【新手進(jìn)階】之八:冒泡排序
【新手進(jìn)階】之九:淺談不綁定數(shù)據(jù)源操作記錄
【新手進(jìn)階】之十:工作日的計(jì)算
【新手進(jìn)階】之十一:“庖丁解!焙汀凹o(jì)昌學(xué)射”——淺談表格式文本數(shù)據(jù)的導(dǎo)入
【新手進(jìn)階】之十二:從四腳騰空的奔馬談起——原來(lái)界面可以這樣設(shè)計(jì)
【新手進(jìn)階】之十三:Outlook風(fēng)格導(dǎo)航界面
【新手進(jìn)階】之十四:倉(cāng)庫(kù)管理系統(tǒng)

本帖被以下淘專(zhuān)輯推薦:

分享到:  QQ好友和群QQ好友和群 QQ空間QQ空間 騰訊微博騰訊微博 騰訊朋友騰訊朋友
收藏收藏1 分享分享 分享淘帖1 訂閱訂閱
2#
 樓主| 發(fā)表于 2012-9-23 02:29:29 | 只看該作者
本帖最后由 roych 于 2012-9-23 21:27 編輯

問(wèn)題3:
取消公共變量之后,實(shí)際上嵌套函數(shù)已經(jīng)發(fā)生很大變化的了。具體過(guò)程是:
第1次傳址過(guò)程,沒(méi)什么好說(shuō)的,x=a+1=2,y=b+1=3,a=x+y=5
第2次傳址過(guò)程,x=x+1=2+1=3,y=y+1=3+1=4,a=x+y=7。
從上面來(lái)看,實(shí)際上第2次傳址過(guò)程并沒(méi)有把a(bǔ)=5傳遞給fun1,而是繼續(xù)進(jìn)行循環(huán)內(nèi)運(yùn)算的(這和定義公共變量是完全不同的),換句話(huà)說(shuō),fun1(a,b)=a+y=7+4=11(這時(shí)候x=3,y=4)。

因此:fun1(fun1(a,b),b)=fun1(11,4),這樣一來(lái),那么顯然循環(huán)就得執(zhí)行4次了。
第1次:x=11+1=12,y=4+1=5,a=12+5=17
第2次:x=12+1=13,y=5+1=6,a=13+6=19
第3次:x=13+1=14,y=6+1=7,a=12+5=21
第4次:x=14+1=15,y=7+1=8,a=13+6=23
那么fun1(fun1(a,b),b)=fun1(11,4)=a+y=23+8=31。
因此得到的結(jié)果,顯然是31,3,8【為什么是3,而不是15?以x才是15,a一直停留在嵌套內(nèi)的循環(huán)里,即x=x+1+1=3。也就是說(shuō),嵌套前a已經(jīng)定型了~~】
*************************************************************************************************
問(wèn)題4:
事實(shí)上這和之前的解釋沒(méi)太大不同。過(guò)程如下:
第1次:x=a+1=2,y=b+1=3,a=x+y=5
第2次:x=x+1=2+1=3,y=y+1=3+1=4,a=x+y=7 fun1(a,b)=7+4=11。
而我們前面說(shuō)過(guò),傳值過(guò)程,傳遞完之后,那個(gè)值是不會(huì)發(fā)生變化的。因此,外循環(huán)也只是循環(huán)2次。即:fun1(fun1(a,b),b)=fun1(11,2)
第1次:x=11+1=12,y=2+1=3,a=x+y=15
第2次:x=12+1=13,y=3+1=4,a=x+y=17
fun1(fun1(a,b),b)=fun1(11,2)=a+y=17+4=21。
b肯定是不變的2了,那么取消公共變量后的a呢?
不用猜了,取消公共變量后,傳值完之后,變量便回復(fù)到初始值了,也就是a=1。會(huì)感到意外嗎?

啰啰嗦嗦地講這么多,也不知道會(huì)不會(huì)有人覺(jué)得,這些代碼到底有沒(méi)有實(shí)際用途呢?事實(shí)上,曾經(jīng)為一個(gè)同事寫(xiě)過(guò)一段ADO的代碼,他問(wèn)了一個(gè)很專(zhuān)業(yè)的問(wèn)題,為什么在Update記錄集后,非要加上一句a=0呢?如果他了解傳值過(guò)程和傳址過(guò)程就很清楚原因了:加上這句后才能初始化數(shù)據(jù)啊。
3#
發(fā)表于 2012-9-23 13:47:37 | 只看該作者
thanks you sharing it
4#
發(fā)表于 2012-9-23 14:38:45 | 只看該作者
學(xué)習(xí)學(xué)習(xí)
5#
發(fā)表于 2012-9-23 15:43:09 | 只看該作者
正好,我這里也有一個(gè),更有意思的!{:soso_e104:}

Sub testFuns()
Dim lngRet As Long, varLong As Long
varLong = 1
fun1 varLong
Debug.Print varLong

varLong = 1
fun1 (varLong)
Debug.Print varLong

varLong = 1
Call fun1(varLong)
Debug.Print varLong
End Sub
Function fun1(ByRef lng As Long) As Integer
lng = 1000
End Function

6#
發(fā)表于 2012-9-23 15:44:11 | 只看該作者
輸出:
1000
1
1000

誰(shuí)知道呢?{:soso_e128:}
7#
發(fā)表于 2012-9-23 15:50:11 | 只看該作者
同樣給出SUB。

Sub testSubs()
Dim lngRet As Long, varLong As Long
varLong = 1
sub1 varLong
Debug.Print varLong

varLong = 1
sub1 (varLong)
Debug.Print varLong

varLong = 1
Call sub1(varLong)
Debug.Print varLong

varLong = 1
Call sub1(lng:=varLong)
Debug.Print varLong

varLong = 1
sub1 lng:=varLong
Debug.Print varLong
End Sub
Sub sub1(ByRef lng As Long)
lng = 1000
End Sub

大家慢慢找答案吧{:soso_e113:}
8#
 樓主| 發(fā)表于 2012-9-23 21:37:34 | 只看該作者
lynnwang 發(fā)表于 2012-9-23 15:43
正好,我這里也有一個(gè),更有意思的!

Sub testFuns()

有點(diǎn)意思,哈哈~~~可以加深大家對(duì)傳址過(guò)程的理解。

點(diǎn)擊這里給我發(fā)消息

9#
發(fā)表于 2012-9-23 21:46:49 | 只看該作者
看了頭會(huì)暈,我還是不看了
10#
發(fā)表于 2012-9-24 20:38:39 | 只看該作者
本帖最后由 ycxchen 于 2012-9-24 20:39 編輯

很長(zhǎng)時(shí)間不見(jiàn)版主有“新手進(jìn)階”東西了,我要學(xué)習(xí)!

點(diǎn)評(píng)

謝謝一貫的支持!只是一方面工作上有點(diǎn)小忙,另一方面也沒(méi)有遇到比較有意思的話(huà)題,所以寫(xiě)的少了些~~本想多寫(xiě)寫(xiě)算法方面的,不過(guò),考慮到在Access中的適用性可能不大,就作罷了。  發(fā)表于 2012-9-24 21:56
您需要登錄后才可以回帖 登錄 | 注冊(cè)

本版積分規(guī)則

QQ|站長(zhǎng)郵箱|小黑屋|手機(jī)版|Office中國(guó)/Access中國(guó) ( 粵ICP備10043721號(hào)-1 )  

GMT+8, 2025-7-13 02:21 , Processed in 0.134321 second(s), 36 queries .

Powered by Discuz! X3.3

© 2001-2017 Comsenz Inc.

快速回復(fù) 返回頂部 返回列表