» 您尚未 登录   注册 | 社区服务 | 帮助 | 社区 | 无图版


常州五颜六色网络技术有限公司 -> 网站建设 -> 最佳ASP.NET编程习惯(1)
 XML   RSS 2.0   WAP 

--> 本页主题: 最佳ASP.NET编程习惯(1) 加为IE收藏 | 收藏主题 | 上一主题 | 下一主题
阿七




该用户目前不在线
级别: 未验证会员
精华: 0
发帖: 909
威望: 0 点
金钱: 2161 RMB
贡献值: 0 点
在线时间:512(小时)
注册时间:2006-03-29
最后登录:2008-08-07
查看作者资料 发送短消息 推荐此帖 引用回复这个帖子

最佳ASP.NET编程习惯(1)

初学编程的朋友往往喜欢收集一些很“奇妙”的编程技巧,然而,技巧的积累往往并没有提高程序质量,反而引导一些编程者一味追求奇和新,忘记了基本编程习惯的培养,不利于团队的合作,可能,这也是中国并不缺少聪明的程序员,但是缺少聪明的开发团队的一个原因吧。在ASP.NET的开发中,可以学习的技巧不少,但是,一些基本的编程习惯我们一定要养成,这样不但能根本上提高程序质量和开发效率,而且,也利于程序的阅读和团队开发。如果自己写的程序只有自己可以看懂或者只有几个人可以看懂,即使程序技巧神乎其技,对于程序的升级和维护都是致命问题。 d ?OsVT; U  
v6KF0mqA&  
  一、 错误(以外)的处理 Bf6\KI<V2  
Q-f?7*>  
  程序健壮性最基本要求就是程序错误的处理与捕捉,在ASP.NET中,错误的处理有和其他编程语言一样的机制,可以使用Try…Catch…Finally等方式,这一点和ASP相比具有较大的进步。而且,使用这些错误处理方法,可以大大提高程序的可读性和程序调试速度,在这几个优势结合的情况下,我们更加应该注意这一点。 z_ia3k<  
关于错误的处理,我们可以参考这篇文章(英文): r(/+- t  
http://www.123aspx.com/redir.aspx?res=28336 q*K.e5"'  
|1"n\4$  
  二、 字符串的处理 | <l=i(  
M!b"c4|<  
  网页设计中,字符串的处理几乎是最常见的了。使用ASP.NET以后,字符串的处理比ASP的速度快,而且,在ASP.NET中,专门增加一个字符串处理类StringBulider,使用这个类可以完成一些常见的字符串操作,而最主要的,使用StringBuilder可以大大提高字符串处理速度。 g E;o_ ~  
在ASP.NET中,最常见的就是使用“&”来连接两个字符串: [5Pin>]z  
Dim myOutputString As String = "My name is" ,qO2D_  
Dim myInputString As String = " Alex" r4Jc9Tv d  
myOutputString = myOutputString & myInputString zvnR'\A_  
Response.Write(myoutputString) XSz)$9~hk  
.Zv uhOn^  
  现在,我们来看看StringBuilder的使用,在使用StringBuilder的时候,我们对字符串可以做一些基本的操作,比如Append、Replace、Insert、Remove等,现在我们来看具体举例。 R8<P}mv  
%13V@'e9  
  (1)StringBuilder中Append的使用 4z>SI\Ss  
  Append和其他语言的Append一样,就是在字符串最后增加其他字符。 H)O I&?  
;*XH[>I  
Dim sb as StringBuilder = New StringBuilder() |jE0H!j  
sb.append( " " ) 5]yby"Z?}  
For i = 0 To RowCount - 1 #Vi:-zyY  
sb.Append(" ") j?y_ H[Z  
For k = 0 To ColCount - 1 8 0;^]l   
sb.Append(" ") Z</.Ss 4  
sb.Append( dt.Rows(i).Item(k, DataRowVersion.Current).toString()) &+zS4)UK  
sb.Append( " " ) Sn!5/9Y  
Next E+e:UBeUV  
sb.Append(" v)J(@>CZ[  
") M|xs>+r*  
Next Y ]6kA5  
sb.Append( " Vmf !0-  
") hO] vy>i;  
Dim strOutput as String = sb.ToString() n!$zO{P  
lblCompany.Text = strOutput ;o-c.-!F  
M=Cl|  
  在以上的程序中,用Append方法实现了一个表格的输出,需要注意的一点是,StringBulider必须首先使用ToString()方法将其转化为String类型才可以直接输出。在以上的举例中,我们看到的全部是Append一个直接的字符串,其实,这个方法有一个很方便的功能,那就是可以直接Append其他类型的变量,比如可以直接Appemd一个Integer类型的数值,当然,我们输出以后自动转化为一个字符串: !{%BfZX<&  
Iu|4QE  
Sub Page_Load(Source As Object, E As EventArgs) A{Dy3tm=  
Dim sb As System.Text.StringBuilder 5Gw B1}q  
Dim varother As Integer hX9vtV5L  
varother=9999 I$HO[Z!  
sb =new System.Text.StringBuilder() "9bd;Tt:  
sb.append("可以Append其他类型:") ]<Kkq !  
sb.append(varother) C 5 xsh  
Response.write(sb.toString()) ?3=y]Vb+  
End Sub fobnK~2  
[H5BIM@{  
(2)字符串中其他方法的使用 Dlqvz|X/  
我们还可以使用其他方法,我们来看看常见的: 5e}adHjM  
Insert方法,可以在指定位置插入其他字符,使用方法:Insert(插入位置,插入字符); Bx 9v2x.  
Remove方法,可以在指定位置删除指定字数字符,使用方法:Remove(其实位置,字符数); GLWEoV9<  
Replace方法,可以替换指定字符,使用方法:replace(被替换字符串,替换字符串) }^tW's8  
字符串的具体介绍和使用方法可以参考以下文章(英文): <e'/z3TbRW  
http://aspfree.com/aspnet/stringbuilder.aspx q@[UeXu?pZ  
http://msdn.microsoft.com/library/en-us/cpref/html/frlrfSystemTextStringBuilderClassTopic.asp IF'Tj`yD  
*!m(oP  
  三、 数据库链接Connection和DataReader的关闭 k$3Iv"gbx  
,4--3 MU  
  在使用ASP编程的时候,我们就已经知道,在使用数据库连接以后,一定要将连接关闭,然后设置为NoThing。在Asp.NET中,我们仍然需要这样使用,不过,在ASP.NET中,由于使用了ADO.NET,所以,在一些相关的处理方面,实际还是有一些细微的区别,而这些区别,往往也就是我们设计的时候最需要注意的。现在,我们通过举例,来看看在常见的ADO.NET操作中,需要注意哪些问题。 <\`qRz0/  
I_\?wSNGM  
(1)举例一 A"i $.dR{  
Dim myConnection As SqlConnection = new SqlConnection(ConfigurationSettings.AppSettings("DSN_pubs")) .oH)eD  
Dim myCommand As SqlCommand = new SqlCommand("Select pub_id, pub_name From publishers", myConnection) z07Xj%zX9  
Dim myDataReader As SqlDataReader PvB{@82  
Try 8 /T[dn  
myConnection.Open() 7Fzj&!>ti  
myDataReader = myCommand.ExecuteReader(CommandBehavior.CloseConnection) 08G${@D+X0  
DropDownList1.DataSource = myDataReader crQ_@@X?<  
DropDownList1.DataBind() D 6,Ol4d  
Catch myException As Exception g&I|@$\  
Response.Write("An error has occurred: " & myException.ToString()) oy\ U\#k   
Finally Qz4Do6#y  
If Not myDataReader Is Nothing Then 9m%2&fjK^  
\\\'关闭DataReader (f;.`W  
myDataReader.Close() MO@XbPZB  
End If d <RJH  
End Try Fv<3VKueK[  
在以上的举例中,我们注意到,这里只关闭了DataReader,并没有关闭Connection。为什么呢?仔细观察以上的ExecuteReader方法,原来,设置了ExecuteReader参数,当执行完ExecuteReader以后,会自动关闭Connection。所以,这样设置以后,就没有必要再手动关闭Connection了。 MU:q`DRr  
4s 6,`-  
(2)举例二 _ B0C]u3D  
GT,1t=|&V  
Dim myConnection As SqlConnection = new SqlConnection(ConfigurationSettings.AppSettings("DSN_pubs")) L~Y^ O`c  
Dim myCommand As SqlCommand = new SqlCommand("Select pub_id, pub_name From publishers", myConnection)  o .*t  
Try OlP1Zd/l  
myConnection.Open() Vsr"W@k_  
DropDownList1.DataSource = myCommand.ExecuteReader() L7[f-cK2:  
DropDownList1.DataBind() 57KrDxE}  
Catch myException As Exception 5mX^{V&^  
Response.Write("An error has occurred: " & myException.ToString()) ;3XOk+  
Finally YJ|U| [  
If Not myConnection Is Nothing AndAlso ((myConnection.State And ConnectionState.Open) = ConnectionState.Open) Then D$+g5u)  
myConnection.Close() Hk'R!X  
End If <G'M/IR a  
End Try zkquXzlgB  
 %C_c%3d  
  在以上的举例中,我们发现,居然没有关闭DataReader。为什么呢?其实上面的代码中,没有直接生成DataReader对象,当然也就无从关闭了。需要注意一点的是,在关闭Connection之前,程序首先判断Connection是否已经打开,如果没有打开,也就没必要关闭了。

[楼 主] | Posted: 2006-04-04 13:57 顶端

常州五颜六色网络技术有限公司 -> 网站建设



Copyright © 2005-2009 5y6s Inc. 苏ICP备05001866号 Powered by PHPWind 5.0.1
Total 0.011370(s) query 4, Gzip enabled
会员言论不代表本站立场 本站法律顾问:北京汇泽律师事务所 韩律师
QQ:点击这里给我发消息 /点击这里给我发消息 /点击这里给我发消息
51La