天天躁日日躁狠狠躁AV麻豆-天天躁人人躁人人躁狂躁-天天澡夜夜澡人人澡-天天影视香色欲综合网-国产成人女人在线视频观看-国产成人女人视频在线观看

asp.net 的錯誤處理機制講解

程序健壯性最基本要求就是程序錯誤的處理與捕捉,在ASP.NET中,錯誤的處理有和其他編程語言一樣的機制,可以使用Try…Catch…Finally等方式,這一點和ASP相比具有較大的進步。而且,使用這些錯誤處理方法,可以大大提高程序的可讀性和程序調試速度,在這幾個優勢結合的情況下,我們更加應該注意這一點。 
關于錯誤的處理,我們可以參考這篇文章:

Try...Catch...Finally in ASP.NET

Introduction
Error handling in Classic ASP was not the best. We were having only limited options available for error handling in Classic ASP such as, "On Error Resume Next". In ASP 3.0 we saw the new ASP object called Error Object. But we were not able to handle all exception/errors efficiently. Now in ASP.NET we have a new error handling mechanism which was already their in other languages such as C, C++ and Java. We can also call the try...catch mechanism as "Exception Handling" 

What is Try...Catch....Finally
This is a new error handling mechanism in VB.NET, so as in ASP.NET. Well we have three blocks of code, were each block has it own functionality. The Try...Catch...Finally block of code surrounds the code where an exception might occur. The simple Try statement comes before the block of code, the Catch block of code is where we specify what type of error to look for, and the Finally block of code is always executed and contains cleanup routines for exception situations. Since the catch block is specific to the type of error we want to catch, we will often use multiple Catch blocks in our Try...Catch...Finally structure. 

A simple Database operation
Dim mySqlConnection as New SqlConnection (ConnectionString) 
Dim mySqlCommand as SqlCommand 
Dim strSql as String 

strSql = "insert into yourtable (f1, f2) values ('f1', 'f2')" 
mySqlCommand = new SqlCommand(strSql, mySqlConnection) 

Try 

mySqlConnection.Open() 
mySqlCommand.ExecuteReader(CommandBehavior.CloseConnection) 
Message.text = "New Forward information added" 

Catch SQLexc as sqlexception 

Message.text = Message.text + sqlexc.tostring() 

Catch exc as exception 

if Instr(1, exc.tostring, "duplicate key") > 0 then 
Message.text = Message.text + "Cannot insert duplicate values." 
else 
Message.text = Message.text + exc.tostring() 
end if 

Finally 

mySqlConnection.Close() 
End Try 


What does the above example exactly do?
Well, in the above example we were trying to insert some values to a database table. The possible chances while performing a database operation are invalid connection string, database server too busy resulting in connection time out, database server not currently running etc etc. We should anticipate all these errors while performing a database operation. So, we have a Try block, which contains the statements such as opening the connection and executing the operation. Basically, we have two major statements inside the try block which may result in an exception/error. 

As I said, any exception can occur during a database operation. Catching all these exception is now very easy with the Catch block. All we need is to have a Catch block. We can have any number of Catch blocks. Each Catch block may have a different error/exception trapping mechanism. In the above example, we have two catch blocks, one which captures a general exception and the other one which traps the SqlException. 

When all the statements inside the catch blocks are executed, the finally block comes into the picture. As I said earlier, finally block contains cleanup routines for exception situations. 

Exit Try statement
We can also have the Exit Try statement inside any of the try...catch block. The objective of this statement is to break out of the Try or Catch block. Once the Exit Try statement is executed, the control goes to the Finally block. So, Exit Try statement can be best used were we need to execute the cleanup routines. 

How about nested Try statments?
We can have nested Try and Catch blocks. Can you imagine, when we should use nested try statements. Well, errors can occur within the Catch portion of the Try structures, and cause further exception to occur. The ability to nest try structures is available so that we can use a second Try structure to cover exceptions. 

Links
http://www.vbweb.co.uk/show/1889/2/ http://www.oreillyNET.com/pub/a/dotNET/2001/09/04/error_handling.html?page=2

AspNet技術asp.net 的錯誤處理機制講解,轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

主站蜘蛛池模板: 日本精品久久久久中文字幕 | 波野结衣qvod | 成在线人免费视频 | 亚洲人精品午夜射精日韩 | 樱花草在线影视WWW日本动漫 | 欧美另类老女人 | 忘忧草研究所 麻豆 | 射漂亮黑b丝女 | 欧美午夜免费观看福利片 | 波多野结衣 无码片 | 果冻传媒我的女老板 | 国产av免费观看日本 | 麻花豆传媒剧国产免费mv观看 | 国产成人久久AV免费看澳门 | 午夜伦理 第1页 | 国产午夜精品自在自线之la | 免费夜色污私人影院网站 | 国产视频这里只有精品 | 亚洲精品久久久久一区二区三 | 亚洲AV久久无码高潮喷水 | 国产成人无码精品久久久免费69 | 国产成人a一在线观看 | 色哟哟网站入口在线观看视频 | 蜜臀AV中文字幕熟女人妻 | 最近日本MV字幕免费观看视频 | 性VIDEOSTV另类极品 | 精品国产品国语在线不卡丶 | 中文字幕无码亚洲视频 | 午夜看片网 | 欧美 日韩 无码 有码 在线 | 人人碰在线视频 | 欧美色偷偷亚洲天堂bt | 99久久免费精品国产 | 内射人妻骚骚骚 | 俄罗斯女肥臀大屁BBW | 国产精品亚洲国产三区 | 色老板美国在线观看 | 日韩在线视频www色 日韩在线看片中文字幕不卡 | 精品国产成人a区在线观看 精品国产成人AV在线看 | 亚洲AV无码专区国产精品99 | 欧美激情视频一区 |