• 设为首页
  • 点击收藏
  • 手机版
    手机扫一扫访问
    迪恩网络手机版
  • 关注官方公众号
    微信扫一扫关注
    公众号

最佳ASP.NET编程习惯

原作者: [db:作者] 来自: [db:来源] 收藏 邀请
初学编程的朋友往往喜欢收集一些很“奇妙”的编程技巧,然而,技巧的积累往往并没有提高程序质量,反而引导一些编程者一味追求奇和新,忘记了基本编程习惯的培养,不利于团队的合作,可能,这也是中国并不缺少聪明的程序员,但是缺少聪明的开发团队的一个原因吧。在ASP.NET的开发中,可以学习的技巧不少,但是,一些基本的编程习惯我们一定要养成,这样不但能根本上提高程序质量和开发效率,而且,也利于程序的阅读和团队开发。如果自己写的程序只有自己可以看懂或者只有几个人可以看懂,即使程序技巧神乎其技,对于程序的升级和维护都是致命问题。 

一、 错误(以外)的处理 
程序健壮性最基本要求就是程序错误的处理与捕捉,在ASP.NET中,错误的处理有和其他编程语言一样的机制,可以使用Try…Catch…Finally等方式,这一点和ASP相比具有较大的进步。而且,使用这些错误处理方法,可以大大提高程序的可读性和程序调试速度,在这几个优势结合的情况下,我们更加应该注意这一点。 
关于错误的处理,我们可以参考这篇文章(英文): 
http://www.123aspx.com/redir.aspx?res=28336 

二、 字符串的处理 
网页设计中,字符串的处理几乎是最常见的了。使用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一样,就是在字符串最后增加其他字符。 
Dim sb as StringBuilder = New StringBuilder() 
sb.append( "<table border='1' width='80%'>" ) 
For i = 0 To RowCount - 1 
sb.Append("<tr>") 
For k = 0 To ColCount - 1 
sb.Append("<td>") 
sb.Append( dt.Rows(i).Item(k, DataRowVersion.Current).toString()) 
sb.Append( "</td>" ) 
Next 
sb.Append("<tr>") 
Next 
sb.Append( "</table>") 
Dim strOutput as String = sb.ToString()  
lblCompany.Text = strOutput 
在以上的程序中,用Append方法实现了一个表格的输出,需要注意的一点是,StringBulider必须首先使用ToString()方法将其转化为String类型才可以直接输出。在以上的举例中,我们看到的全部是Append一个直接的字符串,其实,这个方法有一个很方便的功能,那就是可以直接Append其他类型的变量,比如可以直接Appemd一个Integer类型的数值,当然,我们输出以后自动转化为一个字符串: 
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("<font color='blue'>可以Append其他类型:</font>") 
sb.append(varother) 
Response.write(sb.toString()) 
End Sub 
(2)字符串中其他方法的使用 
我们还可以使用其他方法,我们来看看常见的: 
Insert方法,可以在指定位置插入其他字符,使用方法:Insert(插入位置,插入字符); 
Remove方法,可以在指定位置删除指定字数字符,使用方法:Remove(其实位置,字符数); 
Replace方法,可以替换指定字符,使用方法:replace(被替换字符串,替换字符串) 
字符串的具体介绍和使用方法可以参考以下文章(英文): 
http://aspfree.com/aspnet/stringbuilder.aspx 
http://msdn.microsoft.com/library/en-us/cpref/html/frlrfSystemTextStringBuilderClassTopic.asp 

三、 数据库链接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)举例二 
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是否已经打开,如果没有打开,也就没必要关闭了。 

四、使用Web.Config/Maching.Config保存常用数据 
一些数据我们需要时常使用,比如使用ADO.NET的时候,最常见的就是数据库连接语句,在ASP中,我们常常将这些信息保存在Application中。当然,在ASP.NET中,也可以这样,不过,ASP.NET已经提供一个配置文件WEB.Config,所以,我们最好将这些信息保存在WEB.Config中,当然,我们也可以保存在Machine.Config中,不过,这样的话,整个网站都必须使用,所以,一般我们都使用Web.Config。现在,我们来看具体这个文件的使用。 
(1)Web.Config文件的设置 
首先,我们来看Web.Config的设置,我们在这个文件中增加设置以下两个项目,设置如下: 
<configuration> 
<appsettings> 
<add key="dsn" value="myserver"/> 
<add key="someotherkey" value="somevalue"/> 
</appsettings> 
</configuration> 
(2)变量的使用 
以上XML文件设置了dsn和someotherkey两个变量,现在我们看看程序中怎样使用: 
<html> 
<script language="VB" runat=server> 
Sub Page_Load(Sender as Object, E as EventArgs) 
Dim AppSettings as Hashtable = Context.GetConfig("appsettings") 
DSN.Text = AppSettings("dsn") 
SomeOther.Text = AppSettings("someotherkey") 
End Sub 
</script> 
<body> 
DSN Setting: <asp:label  & myVariable.ToString()) 
以上设置我们可以看出,在ASP.NET中,程序调试功能已经很方便简单了,我们在程序设计中如果忽略这些特点,继续采用ASP的思维来设计程序,那么我们的程序不但效率没有提高,也增加了其他开发者合作的难度。 

六、总结 
以上的一些程序编写习惯,我们可以慢慢养成,在程序设计的时候,不要太在意程序是否最简洁灵活,对于一般开发者而言,程序规范化和可读性可能比追求程序的灵活性更加重要。在互联网资源越来越丰富的情况下,我们可以参考一些很规范的程序源代码来学习,当然,最好的莫过于微软自己的东西,我们可以参考以下网址:http://www.asp.net,关于更多的程序编写问题,我们可以参考以下网址: 
http://www.gotdotnet.com/team/asp/ASP.NET%20Performance%20Tips%20and%20Tricks.aspx 

鲜花

握手

雷人

路过

鸡蛋
该文章已有0人参与评论

请发表评论

全部评论

专题导读
热门推荐
热门话题
阅读排行榜

扫描微信二维码

查看手机版网站

随时了解更新最新资讯

139-2527-9053

在线客服(服务时间 9:00~18:00)

在线QQ客服
地址:深圳市南山区西丽大学城创智工业园
电邮:jeky_zhao#qq.com
移动电话:139-2527-9053

Powered by 互联科技 X3.4© 2001-2213 极客世界.|Sitemap