zoukankan      html  css  js  c++  java
  • 作为ASP.NET开发人员必须养成的编程习惯(转载:51CTO)

    1.错误(以外)的处理

    程序健壮性最基本要求就是程序错误的处理与捕捉,在ASP.NET中,错误的处理有和其他编程语言一样的机制,可以使用Try…Catch… Finally等方式,这一点和ASP相比具有较大的进步。而且,使用这些错误处理方法,可以大大提高程序的可读性和程序调试速度,在这几个优势结合的情况下,我们更加应该注意这一点。

    2.字符串的处理

    网页设计中,字符串的处理几乎是最常见的了。使用ASP.NET以后,字符串的处理比ASP的速度快,而且,在ASP.NET中,专门增加一个字符串处理类StringBulider,使用这个类可以完成一些常见的字符串操作,而最主要的,使用StringBuilder可以大大提高字符串处理速度。

    在ASP.NET中,最常见的就是使用“&”来连接两个字符串:

    Dim myOutputString As String = "My name is"
    Dim myInputString As String = " Alex"
    myOutputString = myOutputString & myInputString
    Response.Write(myoutputString)

    现在,我们来看看StringBuilder的使用,在使用StringBuilder的时候,我们对字符串可以做一些基本的操作,比如Append、Replace、Insert、Remove等,现在我们来看具体举例。

    (1)StringBuilder中Append的使用

    Append和其他语言的Append一样,就是在字符串最后增加其他字符。

    http://www.CodeHighlighter.com/
    -->Dim sb as StringBuilder = New StringBuilder()
    sb.append( " " )
    For i = 0 To RowCount - 1
    sb.Append(" ")
    For k = 0 To ColCount - 1
    sb.Append(" " )
    Next
    sb.Append(" ")
    Next
    sb.Append( "
    ")
    sb.Append( dt.Rows(i).Item(k, DataRowVersion.Current).toString())
    sb.Append( "
    ")
    Dim strOutput as String = sb.ToString()
    lblCompany.Text = strOutput

    在以上的程序中,用Append方法实现了一个表格的输出,需要注意的一点是,StringBulider必须首先使用ToString()方法将其转化为String类型才可以直接输出。在以上的举例中,我们看到的全部是Append一个直接的字符串,其实,这个方法有一个很方便的功能,那就是可以直接 Append其他类型的变量,比如可以直接Appemd一个Integer类型的数值,当然,我们输出以后自动转化为一个字符串:

    http://www.CodeHighlighter.com/
    -->Sub Page_Load(Source As Object, E As EventArgs)
    Dim sb As System.Text.StringBuilder
    Dim varother As Integer
    varother=9999
    sb =new System.Text.StringBuilder()
    sb.append("可以Append其他类型:")
    sb.append(varother)
    Response.write(sb.toString())
    End Sub

    (2)字符串中其他方法的使用

    我们还可以使用其他方法,我们来看看常见的:

    Insert方法,可以在指定位置插入其他字符,使用方法:Insert(插入位置,插入字符);

    Remove方法,可以在指定位置删除指定字数字符,使用方法:Remove(其实位置,字符数);

    Replace方法,可以替换指定字符,使用方法:replace(被替换字符串,替换字符串)

    3.数据库链接Connection和DataReader的关闭

    在使用ASP编程的时候,我们就已经知道,在使用数据库连接以后,一定要将连接关闭,然后设置为NoThing。在Asp.NET中,我们仍然需要这样使用,不过,在ASP.NET中,由于使用了ADO.NET,所以,在一些相关的处理方面,实际还是有一些细微的区别,而这些区别,往往也就是我们设计的时候最需要注意的。现在,我们通过举例,来看看在常见的ADO.NET操作中,需要注意哪些问题。

    (1)举例一

    Dim myConnection As SqlConnection = 
    new SqlConnection(ConfigurationSettings.AppSettings("DSN_pubs"))
    Dim myCommand As SqlCommand =
    new SqlCommand("Select pub_id, pub_name From publishers", myConnection)
    Dim myDataReader As SqlDataReader
    Try
    myConnection.Open()
    myDataReader = myCommand.ExecuteReader(CommandBehavior.CloseConnection)
    DropDownList1.DataSource = myDataReader
    DropDownList1.DataBind()
    Catch myException As Exception
    Response.Write("An error has occurred: " & myException.ToString())
    Finally
    If Not myDataReader Is Nothing Then
    \\\'关闭DataReader
    myDataReader.Close()
    End If
    End Try

    在以上的举例中,我们注意到,这里只关闭了DataReader,并没有关闭Connection。为什么呢?仔细观察以上的ExecuteReader方法,原来,设置了ExecuteReader参数,当执行完ExecuteReader以后,会自动关闭Connection。所以,这样设置以后,就没有必要再手动关闭Connection了。

    (2)举例二

    http://www.CodeHighlighter.com/
    -->Dim myConnection As SqlConnection =
    new SqlConnection(ConfigurationSettings.AppSettings("DSN_pubs"))
    Dim myCommand As SqlCommand =
    new SqlCommand("Select pub_id, pub_name From publishers", myConnection)
    Try
    myConnection.Open()
    DropDownList1.DataSource = myCommand.ExecuteReader()
    DropDownList1.DataBind()
    Catch myException As Exception
    Response.Write("An error has occurred: " & myException.ToString())
    Finally
    If Not myConnection Is Nothing AndAlso
    ((myConnection.State And ConnectionState.Open) = ConnectionState.Open) Then
    myConnection.Close()
    End If
    End Try

    在以上的举例中,我们发现,居然没有关闭DataReader。为什么呢?其实上面的代码中,没有直接生成DataReader对象,当然也就无从关闭了。需要注意一点的是,在关闭Connection之前,程序首先判断Connection是否已经打开,如果没有打开,也就没必要关闭了。

  • 相关阅读:
    关于遇到问题的解决方法(仅此献给初学者吧,我工作还没两年,这点经验对于大神,不值一谈的)
    chm TO html 另类方法
    Android EditText setOnClickListener事件 只有获取焦点才能响应 采用setOnTouchListener解决
    Jquery UI 中Tree组件的json格式,java递归拼接demo
    汇编 二则运算
    创建 macvlan 网络
    准备 macvlan 环境
    overlay 是如何隔离的?- 每天5分钟玩转 Docker 容器技术(53)
    overlay 如何实现跨主机通信?- 每天5分钟玩转 Docker 容器技术(52)
    在 overlay 中运行容器
  • 原文地址:https://www.cnblogs.com/renjie/p/1493586.html
Copyright © 2011-2022 走看看