重庆分公司,新征程启航
为企业提供网站建设、域名注册、服务器等服务
事实上,在B =阵列(...)数组参数短语的主要问题是2,5,3,所以这些整数数组()函数的返回值类型的一个变种,而不是塑料。在指定的子数组参数的定义是一个整数,导致类型不匹配错误。
榕江ssl适用于网站、小程序/APP、API接口等需要进行数据传输应用场景,ssl证书未来市场广阔!成为成都创新互联的ssl证书销售渠道,可以享受市场价格4-6折优惠!如果有意向欢迎电话联系或者加微信:028-86922220(备注:SSL证书合作)期待与您的合作!
使用下面的方法解决这个问题:
定义函数的参数类型,
。私人小组代码(1为ByRef(带),作为字符串BYVAL myStr中)
你提到的原因,后的ByRef参数类型不匹配,因为默认情况下是作为一个参数传递的函数地址,你的第二个参数myStr的前面不限制转让其参数,系统,与前一个()相同的地址,已成为通过轻轻是一个错误,只要在前面加1 BYVAL。
后的代码如下(调试通过):
选项??基地1
。私人小组代码(1为ByRef(带),作为字符串BYVAL myStr中)
??作为字符串昏暗的通道,C1为字符串
?N = UBound的(一) - LEN(myStr中)
?如果N 0?
???myStr的= myStr的字符串$(“*”)
??结束如果
??CH = myStr的
??对于k = 1,UBound的(一)
???C1 = MID(myStr中,K,1)
???N = A(K)
???中$(CH,N)= C1
K-?
??myStr的= CH
?打印myStr的?
END SUB
私人小组Command1_Click()
昏暗的b()
B =阵列(2,5,3,7,6,1,4)
MYNAME =“克莱门特”
调用的代码(二MYNAME)
END SUB
这里觉得没有区别,是因为在SubAddRow 里,我们并没有试图改变形参 t 本身,我们所做的改变都是 t.Rows,我们为 t 添加了行。
对于形参和实参而言,在ByVal 模式下 temTable 和 t 指向了同一块内存,但是这两个变量本身并不在同一个地址上。在改变 t.Rows时,由于二者都指向同一块内存,所以更改了t.Rows里的行数据;
在ByRef模式下,temTable 和 t 就是同一块内存,二者在一个地址上,肯定也就指向同一块内存,在改变 t.Rows时,就是对 temTable 的改变。
在此举个例子:假设我们需要将 temTable 清空,那么我们还是以 t 作为形参,我们可以这样写:
' ByVal 方式传参
Private Sub ClearRow(ByVal t As DataTable)
t = Nothing
End Sub
' ByRef 方式传参
Private Sub ClearRow(ByRef t As DataTable)
t = Nothing
End Sub
' 并且这样调用
Private Sub Button3_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles Button3.Click
ClearRow(temTable)
DataGridView1.DataSource = temTable
End Sub
这样,就是有区别的了。ByVal方式时,虽然 t 被置为 Nothing ,但是由于 t 和 temTable 并不是一个变量,并不在同一个地址上,所以 temTable 没有变。
而 ByRef 时,t 和 temTable 就是同一个变量,在同一个地址上,t = Nothing的同时,temTable 也就是Nothing了。
如果这个解释还不清楚,可以追问。
括号里只能传参数,不能传过程和函数,形参的参数类型按需要写,不知道该写啥就不写,但是不写容易出错
你想在过程B内部调用A过程,直接call A就行