作为ASP.NET开发人员必须养成的编程习惯

开发 后端
良好的习惯对于人的成长是非常重要的,良好的编程习惯对于我们编程能力的提高也是非常重要的。我们编程时要有良好的风格,源代码的逻辑简明清晰,易读易懂是好程序的重要标准。

51CTO编辑推荐《ASP.NET视频教程

让我们的程序写得更加平易近人,更加生动对我们的编程是大有益处的。对我们的程序学习也能起到事半功倍的作用。编程过程中遵守的不成文的标准,对于我们和他人的交流和自己的再学习都是有益无害的。毕竟有时我们写的程序不是只给自己看的,也不是一时兴起,不管以后。 好的编码可使源代码的可读性强且意义清楚,与其他语言约定相一致,并且尽可能直观。

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是否已经打开,如果没有打开,也就没必要关闭了。

【编辑推荐】

【责任编辑:彭凡 TEL:(010)68476606】
责任编辑:彭凡 来源: IT168
相关推荐

2022-07-04 08:00:00

Web开发人员编程习惯程序员

2009-07-20 16:45:41

使用StringBuiASP.NET

2009-07-24 18:02:46

ASP.NET编程

2009-06-25 09:04:22

.NET开发人员

2023-12-25 07:58:46

Python开发.NET

2020-05-25 16:36:19

开发工具编码

2018-04-08 10:08:43

开发人员工具

2012-05-17 10:03:25

.NET

2020-06-11 08:29:29

开发人员代码开发

2023-10-13 18:10:14

编程语言Rust

2009-12-07 16:07:19

WCF编程

2024-10-14 08:00:00

零信任开发网络威胁

2019-11-25 09:41:28

开发者技能工具

2020-04-20 09:57:00

开发工具技术

2009-12-25 10:11:22

.NET Framew

2020-06-28 09:56:48

.NET开发工具

2010-11-02 15:26:32

MVC开发工具

2020-05-11 10:25:38

编程语言J开发Python

2022-12-01 10:05:19

2010-08-09 16:09:25

点赞
收藏

51CTO技术栈公众号