中国IT动力,最新最全的IT技术教程
最新100篇 | 推荐100篇 | 专题100篇 | 排行榜 | 搜索 | 在线API文档 | 网通镜像
首 页 | 程序开发 | 操作系统 | 软件应用 | 图形图象 | 网络应用 | 精文荟萃 | 教育认证 | 硬件维护 | 未整理篇 | 站长教程
ASP JS PHP工程 ASP.NET 网站建设 UML J2EESUN .NET VC VB VFP 网络维护 数据库 DB2 SQL2000 Oracle Mysql
服务器 Win2000 Office C DreamWeaver FireWorks Flash PhotoShop 上网宝典 CorelDraw 协议大全 网络安全 微软认证
硬件维护  CPU  主板  硬盘  内存  显卡  显示器  键盘鼠标  声卡音箱  打印机  机箱电源  BIOS  网卡  C#  Java  Delphi  vs.net2005
  当前位置:> 程序开发 > 编程语言 > .NET > 临时文章
调用另外一个同名的重载函数漏掉括号出现的严重问题
作者:未知 时间:2005-03-14 12:12 出处:Blog 责编:chinaitpower
              摘要:暂无

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

关闭本页
 
首页 | 投资与合作 | 服务条款 | 隐私政策 | 收藏本站 | 设为首页 | 新用户注册 | 免责声明 | 使用帮助
Copyright ©2005-2008 chinaitpower.com All rights reserved. www.chinaitpower.com 版权所有