ASP.NET(C#)中的try catch异常处理机制

在开发一个Umbraco平台系统的过程中,遇到了问题。 写的代码如下

fileUrl = MediaHelper.GetMediaUrl(Convert.ToInt32(publishedContent.GetProperty("mediaPdf").DataValue.ToString()));

这个是在Umbraco后台建立了一个pdfInfo的DocumentType, 它里面有个属性是mediaPicker, 从media文件夹中选取pdf文件。这个属性名称是mediaPdf, 这里就是获取mediaPdf的属性值(节点ID), 转化为Int32类型,然后来获取这个pdf在media folder文件夹

下的url. 

现在有个问题是,content Editor在Umbraco后台,增加一个pdfInfo类型的DocumentType时,忘记添加mediaPdf属性了,也就是说没有从Media文件夹中选择文件,那么这个属性值就是空值,转化为Int32类型Convert.ToInt32就会报错

如何解决呢 ? 写如下语句

  var fileUrl = "";
                try
                {
                    fileUrl = MediaHelper.GetMediaUrl(Convert.ToInt32(publishedContent.GetProperty("mediaPdf").DataValue.ToString()));
                }
                catch (Exception e)
                {

                }

这里就是使用了Try Catch语句块

catch语句中使用如下方式:

catch( Exception  e )

{ }

将在任何情况下,编译都能通过

以下是对Try Catch语句块的理解

通常我们在编程时,将可能引发异常的代码节放在 Try 块中,而将处理异常的代码放在 Catch 块中。Catch 块是一系列以关键字 catch 开头的语句,语句后跟异常类型和要执行的操作。

 

下面详细讲解一下 try catch 的用法:

转载自 http://blog.csdn.net/studyofnet/article/details/13083999 

异常的概述:

 

1、在应用程序遇到异常情况(如被零除情况或内存不足警告)时,就会产生异常。

2、在可能引发异常的语句周围使用 try 块。

3、try 块中发生异常后,控制流会立即跳转到关联的异常处理程序(如果存在)。

4、如果给定异常没有异常处理程序,则程序将停止执行,并显示一条错误消息。

5、如果 catch 块定义了一个异常变量,则可以使用它来获取有关所发生异常的类型的更多信息。

6、可能导致异常的操作通过 try 关键字来执行。

7、异常处理程序是在异常发生时执行的代码块。在 C# 中,catch 关键字用于定义异常处理程序。

8、程序可以使用 throw 关键字显式地引发异常。

9、异常对象包含有关错误的详细信息,比如调用堆栈的状态以及有关错误的文本说明。

10、即使引发了异常,finally 块中的代码也会执行,从而使程序可以释放资源。

 

异常通用用法:

try  
{  
 //程序代码块;  
 //尽力执行该代码块,并捕捉可能发生的异常  
}  
catch(Exception e)   
{  
//异常处理代码块;若异常不被处理,程序将会中止。  
   
//一个try,可对应多个catch,异常处理机制会搜寻参数与异常类型相符的,进入那个catch从句。必须正确排列捕获异常的catch子句,范围小的Exception放在前面的catch。即如果Exception之间存在继承关系,就应把子类的Exception放在前面的catch子句中。  
   
//若当前处理不了该异常,那么把它再抛出。也可在此再抛出异常,实现对错误的封装;  
   
//没有表达式的throw(throw;),将会再次抛出被catch捕捉到的异常。  
   
//使用不带参数的catch子句,则可以捕获任意类型的异常  
}  
finally  
{  
//存在于异常处理的标准事件流之外。  
   
//用来清理资源或还原相关设置信息等其他操作  
   
//是否发生异常,均要执行的代码块;  
}  

异常处理使用建议:

 

 

1、不要返回错误代码。异常是报告框架中的错误的主要手段。

2、尽可能不对正常控制流使用异常。除了系统故障及可能导致争用状态的操作之外,框架设计人员还应设计一些 API 以便用户可以编写不引发异常的代码。例如,可以提供一种在调用成员之前检查前提条件的方法,以便用户可以编写不引发异常的代码。

3、不要包含可以根据某一选项引发或不引发异常的公共成员。

4、不要包含将异常作为返回值或输出参数返回的公共成员。

5、考虑使用异常生成器方法。从不同的位置引发同一异常会经常发生。为了避免代码膨胀,请使用帮助器方法创建异常并初始化其属性。

6、避免从 finally 块中显式引发异常。可以接受因调用引发异常的方法而隐式引发的异常。

posted on 2016-11-08 05:02  新西兰程序员  阅读(948)  评论(0编辑  收藏  举报