阿七
级别: 未验证会员
精华:
0
发帖: 909
威望: 0 点
金钱: 2161 RMB
贡献值: 0 点
在线时间:512(小时)
注册时间:2006-03-29
最后登录:2008-08-07
|
最佳ASP.NET编程习惯(1)
初学编程的朋友往往喜欢收集一些很“奇妙”的编程技巧,然而,技巧的积累往往并没有提高程序质量,反而引导一些编程者一味追求奇和新,忘记了基本编程习惯的培养,不利于团队的合作,可能,这也是中国并不缺少聪明的程序员,但是缺少聪明的开发团队的一个原因吧。在ASP.NET的开发中,可以学习的技巧不少,但是,一些基本的编程习惯我们一定要养成,这样不但能根本上提高程序质量和开发效率,而且,也利于程序的阅读和团队开发。如果自己写的程序只有自己可以看懂或者只有几个人可以看懂,即使程序技巧神乎其技,对于程序的升级和维护都是致命问题。 7INk_2 c|wCKn}` 一、 错误(以外)的处理 b5ie <s
67<CbQZoN3 程序健壮性最基本要求就是程序错误的处理与捕捉,在ASP.NET中,错误的处理有和其他编程语言一样的机制,可以使用Try…Catch…Finally等方式,这一点和ASP相比具有较大的进步。而且,使用这些错误处理方法,可以大大提高程序的可读性和程序调试速度,在这几个优势结合的情况下,我们更加应该注意这一点。 CKARg8o 关于错误的处理,我们可以参考这篇文章(英文): !awh*Xj6 http://www.123aspx.com/redir.aspx?res=28336 3
%(Y$8U {KaN,td9 二、 字符串的处理 ui.'^F< 7#4%\f+'t 网页设计中,字符串的处理几乎是最常见的了。使用ASP.NET以后,字符串的处理比ASP的速度快,而且,在ASP.NET中,专门增加一个字符串处理类StringBulider,使用这个类可以完成一些常见的字符串操作,而最主要的,使用StringBuilder可以大大提高字符串处理速度。 0*(K DDv 在ASP.NET中,最常见的就是使用“&”来连接两个字符串: *Jnh";~b Dim myOutputString As String = "My name is" `\FI7s3b Dim myInputString As String = " Alex" P!\hnm)%4 myOutputString = myOutputString & myInputString I{n;4? Response.Write(myoutputString) +B
B0wY ]UUI~sFE 现在,我们来看看StringBuilder的使用,在使用StringBuilder的时候,我们对字符串可以做一些基本的操作,比如Append、Replace、Insert、Remove等,现在我们来看具体举例。 IlHY%8F{ yuNfhK/#r (1)StringBuilder中Append的使用 OAok Append和其他语言的Append一样,就是在字符串最后增加其他字符。 Z*bC#s? 2,AaP*, Dim sb as StringBuilder = New StringBuilder() Qyj(L[K J sb.append( " " ) R`He^ For i = 0 To RowCount - 1 /_OOPt=G sb.Append(" ") R#0{Wg0O) For k = 0 To ColCount - 1 Z\!rH"8 sb.Append(" ") 7Dl%UG] sb.Append( dt.Rows(i).Item(k, DataRowVersion.Current).toString()) h
PPB45^ sb.Append( " " ) rA#s Next IIP.yyh> sb.Append(" <|JU(B ") _<u;4RO(s Next Yq0# #__ sb.Append( " {bTeAfbf] ") `cO|RhD@ Dim strOutput as String = sb.ToString() cj^bh lblCompany.Text = strOutput _?Ckq :)LC gIQo 在以上的程序中,用Append方法实现了一个表格的输出,需要注意的一点是,StringBulider必须首先使用ToString()方法将其转化为String类型才可以直接输出。在以上的举例中,我们看到的全部是Append一个直接的字符串,其实,这个方法有一个很方便的功能,那就是可以直接Append其他类型的变量,比如可以直接Appemd一个Integer类型的数值,当然,我们输出以后自动转化为一个字符串: ;Id"n7W 7sguGwg) _ Sub Page_Load(Source As Object, E As EventArgs) 8bbVbP Dim sb As System.Text.StringBuilder 'fl(N2t Dim varother As Integer ]+lF=kkc% varother=9999 'RQiLUF sb =new System.Text.StringBuilder() +I.v!P!^ sb.append("可以Append其他类型:") \d5}5J]a&n sb.append(varother) ?1$\pq^ Response.write(sb.toString()) 0lf"w@/ End Sub Xr2 Wa %Y 2G (2)字符串中其他方法的使用 q06@SD$
我们还可以使用其他方法,我们来看看常见的: ^@N`e1 Insert方法,可以在指定位置插入其他字符,使用方法:Insert(插入位置,插入字符); gQ,4xTX Remove方法,可以在指定位置删除指定字数字符,使用方法:Remove(其实位置,字符数); Y)v% Replace方法,可以替换指定字符,使用方法:replace(被替换字符串,替换字符串) i2U/RXu 字符串的具体介绍和使用方法可以参考以下文章(英文): d~,n_E$q; http://aspfree.com/aspnet/stringbuilder.aspx )Kr(Y.w http://msdn.microsoft.com/library/en-us/cpref/html/frlrfSystemTextStringBuilderClassTopic.asp LiF.w:} R1~7F{FW 三、 数据库链接Connection和DataReader的关闭 X)y*#U I'P.K| "R 在使用ASP编程的时候,我们就已经知道,在使用数据库连接以后,一定要将连接关闭,然后设置为NoThing。在Asp.NET中,我们仍然需要这样使用,不过,在ASP.NET中,由于使用了ADO.NET,所以,在一些相关的处理方面,实际还是有一些细微的区别,而这些区别,往往也就是我们设计的时候最需要注意的。现在,我们通过举例,来看看在常见的ADO.NET操作中,需要注意哪些问题。 ~"\P~cg0J lvG3<ls0K$ (1)举例一 F-i&M1\_ Dim myConnection As SqlConnection = new SqlConnection(ConfigurationSettings.AppSettings("DSN_pubs")) eNivlJ,K|@ Dim myCommand As SqlCommand = new SqlCommand("Select pub_id, pub_name From publishers", myConnection) %va[jJ Dim myDataReader As SqlDataReader VJGwd`qo*A Try J (=4 myConnection.Open() Us*Vn myDataReader = myCommand.ExecuteReader(CommandBehavior.CloseConnection) Scf.4~H 0 DropDownList1.DataSource = myDataReader 40rZ~!} DropDownList1.DataBind() mJ/^BT] Catch myException As Exception C?bXrG\ Response.Write("An error has occurred: " & myException.ToString()) v)TUg0U=, Finally eN Hpgj If Not myDataReader Is Nothing Then Y{`3`Pg&N \\\'关闭DataReader ya;@<b myDataReader.Close() 9$8X>T^ End If "Fo End Try -i2D#i' 在以上的举例中,我们注意到,这里只关闭了DataReader,并没有关闭Connection。为什么呢?仔细观察以上的ExecuteReader方法,原来,设置了ExecuteReader参数,当执行完ExecuteReader以后,会自动关闭Connection。所以,这样设置以后,就没有必要再手动关闭Connection了。 ik8|9m4/ 7O]J^H+7 (2)举例二 }3LBbG0Bw $gXkx D Dim myConnection As SqlConnection = new SqlConnection(ConfigurationSettings.AppSettings("DSN_pubs")) 8Ix-i Dim myCommand As SqlCommand = new SqlCommand("Select pub_id, pub_name From publishers", myConnection) ,M| QN* Try S5zpUF= myConnection.Open() f6@^Mg DropDownList1.DataSource = myCommand.ExecuteReader() F0X5dv DropDownList1.DataBind() y^5T/M Catch myException As Exception Cmp{F N"o Response.Write("An error has occurred: " & myException.ToString()) B4PW4>GF
Finally U& | |