当前位置: 首页 > 图文教程 > 网络编程 > ASP.NET > 调用另外一个同名的重载函数漏掉括号出现的严重问题

ASP.NET
DVNEWS 3.2 1013版免虚拟目录的安装方法,只要三个步骤
DataRow的序列化问题
VB.net基础:使用UDP发送和接收消息
采用HttpModules来重写URLs(实践篇)
要用到事务了
DataGrid中单元格的比较
动态引用WebService,建立WebService虚拟机
[初学VB.NET]数据绑定
使用ASP调用WebService时不能以Name为数据库中的字段
在VB.NET里操作文本文件
web下打印的办法
怎样把SQL_SERVER数据库里的(类型是image)图片显示在aspx页面里的image控件里
C#中字符串的加密
中小企业信息应用的利器:DAP-Dynamic Applications Platform
数据库系统概论学习笔记
体会到译者的艰辛,也发现了他们犯的错误
IISManager V1.1 是一个在线管理IIS,维护站点组件,安全稳定,最重要的是完全免费。
VS FlexGridPro 8.0如何在window98运行---有没有升级版本,急请高手指点
给立方体添加纹理
Wrox的C#高级编程第三版第一部分第一章(1~9页)

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


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-11-03   浏览: 34 ::
收藏到网摘: n/a


我的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 语句时函数才返回控制。这样就可以先分配一个初步的值,以后如有必要再进行调整。