前段时间利用了一点空闲时间优化了项目中的代码,其中减少Try/Catch是这次优化的重点。
主要是参考了老A的大作:如何编写没有Try/Catch的程序,看了一下,老A主要介绍了怎么减少按钮事件中的Try/Catch,不过我们项目是WCF,基本上就没有按钮事件,不过老A也提供了一个很好的思路,那就是利用委托动态的为每个方法加上Try/Catch,有了这个思路之后就很好做了。
核心代码:
1 private T InvokeHandler<T>(string clientName, string methodName, Delegate delegateWarpper, object[] parameters)
2 {
3 try
4 {
5 //这边关于第一个参数要注意一下
6 //当委托绑定的方法是静态的,那么就可以传“null”
7 //如果绑定的方法不是静态的,就必须传当前方法的实例才行,也就是 -- delegateWarpper.Target
8 //如果还不懂,直接MSDN查找,我也是看MSDN的
9 return (T)delegateWarpper.Method.Invoke(delegateWarpper.Target, parameters);
10 }
11 catch (TargetInvocationException exception)
12 {
13 Console.WriteLine(exception.InnerException.Message + Environment.NewLine + exception.InnerException.StackTrace);
14 }
15 return default(T);
16 }
原有的调用方式:
1 public List<string> GetNames(string clientName)
2 {
3 //如果每个方法都这样写,那么就要有很多相似的Try/Catch代码
4 //不仅写了很多多余的代码,有使得代码不够优美了
5 try
6 {
7 return new List<string>() { "12" };
8 }
9 catch (Exception exception)
10 {
11 Console.WriteLine(exception.Message + Environment.NewLine + exception.StackTrace);
12 }
13 return null;
14 }
现在的调用方式:
1 public List<string> GetNames(string clientName)
2 {
3 //首先定义委托绑定的方法
4 //可以使用.NET Framework中自带的Action和Func委托
5 Func<List<string>> func = () => new List<string> { "12" };
6 //然后调用助手方法就可以了
7 return InvokeHandler<List<string>>(clientName, "GetNames", func, null);
8 }
通过旧的和新的调用方式比较,发现代码有了很大的缩减,而且从代码整洁的角度来看新的调用方式更加优美。
这个方法不是万能的,不过应对80%的情况还是没有问题滴!
好了,如果园友很有什么好的看法,提出来分享下,Thanks.......
最后祝大家2013春节快乐!
以同步至:个人文章目录索引