调用另外一个同名的重载函数漏掉括号出现的严重问题

王朝c#·作者佚名  2006-12-17
宽屏版  字体: |||超大  

我的ASP.NET不能调试了,由于只是改一个页面,觉的不调试也行吧。仔细检查一下代码就可以了。

可是今天碰到的问题实在是没有检查出来,后来把代码拷贝到笔记本上调试,单步跟踪一下就找出问题来了!

Public Function GetInsertSql() As String

Dim strSql As String

strSql = String.Format('Insert Into {0}(inputID,itemID, 数据) values({1},{2},{3});', _TableData, _ReportID, _ItemID, _value)

Return strSql

End Function

Public Function GetInsertSql(ByVal ddl As DropDownList) As String

If ddl.Items.Count = 0 Then

Return GetInsertSql '这里少了括号,应该是Return GetInsertSql()

'因为在VB.NET中函数名代表要返回的对象,编译不会出现错误。

'如果是直接用GetInsertSql的话是个Nothing

'如果是GetInsertSql()表示调用上面的重载函数GetInsertSql(),这样才是正确的

'可以这样理解: 系统隐式的声明了一个这样的变量,变量名是函数名,类型是函数的返回类型

End If

Dim strSql As String = ''

Dim V As Double

Dim sel As String = ddl.SelectedValue

For Each item As ListItem In ddl.Items

V = IIf(item.Value = sel, _value, 0)

strSql &= String.Format('Insert Into {0}(inputID,itemID,数据,版种) values({1},{2},{3},'{4}');', _TableData, _ReportID, _ItemID, V, item.Text.Trim())

Next

Return strSql

End Function

真是个很隐蔽的错误,以后要注意了,括号自己加上的好(以前都是VB.NET自动加上括号的)

对于这样的问题,编译器应该提出警告才对,或者当取消用函数名来代表返回值。

虽然MSDN是这样赞美的:

将返回值分配给函数名的优点是,直到程序遇到 Exit Function 或 End Function 语句时函数才返回控制。这样就可以先分配一个初步的值,以后如有必要再进行调整。

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
© 2005- 王朝网络 版权所有