4 回答

TA貢獻1780條經驗 獲得超5個贊
Function:函數,可以帶返回值
語法:
Sub SubName(參數1, 參數2,...)
....
End Sub
Function FunctionName(參數1, 參數2,...)
...
FunctionName = 返回值
End Function
調用方法:
Sub直接用 SubName 參數1, 參數2,...
Function如果不要返回值用 FunctionName 參數1, 參數2,...
如果要返回值 Result = FunctionName(參數1, 參數2,...)
語法是這樣,這是對的
Sub SubName(參數1, 參數2,...)
....
End Sub
Function FunctionName(參數1, 參數2,...)
...
FunctionName = 返回值
End Function
調用時:
sub 只能用:
SubName 參數1, 參數2,...
函數則:
變量=FunctionName (參數1, 參數2,...)
FunctionName 參數1, 參數2,...
上面均未講出根本:
SUB與FUNCTION均可有返回值。所以首先要講清返回方式:有兩種,過程或函數返回,即分配與過程或函數同名的返回變量地址。function分配,但sub不分配。VB用此方式加以區分,VC則用VOID聲明不用分配。即如p=aa()若aa()是sub則什么也得不到,還會報錯。但函數則會得到數值。其次,參數返回,VB中缺省用地址傳參,即能返回。但聲明為BYVAL即值傳參,則不可返回,所以,不存在靈活性的差別。比如函數function bb(a,b), 調用時可以bb m, n也可以p=bb(m,n). 實際,如果確認不會失敗,才能用SUB,否則,必須要用FUNCTION以確認是否成功或取得返回值。所以編程,應少用SUB,少用 SubName 參數1, 參數2,...的調用方式。
sub是過程不需要返回值,function是函數,需要返回值,如下:
Function NameOfFunction(parameter1, parameter2)
'some code
NameOfFunction = return value
End Function

TA貢獻1862條經驗 獲得超6個贊
Function: 函數(有返回值且必須返回)
Procedure: 過程(可以無返回,也可以返回值或返回表)
Package: 包(相當于一個容器,將邏輯上相關的函數、過程、變量、常量和游標組合成一個更大的單位)
添加回答
舉報