讓我們的程序寫得更加平易近人,更加生動對我們的編程是大有益處的。對我們的程序學習也能起到事半功倍的作用。編程過程中遵守的不成文的標准,對於我們和他人的交流和自己的再學習都是有益無害的。畢竟有時我們寫的程序不是只給自己看的,也不是一時興起,不管以後。 好的編碼可使源代碼的可讀性強且意義清楚,與其他語言約定相一致,並且盡可能直觀。
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( " ")
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是否已經打開,如果沒有打開,也就沒必要關閉了。