/CleanAOP

Aop in C#

Primary LanguageC#

#CleanAOP--简介

作者:立地(欧文)
邮箱:jarvin_g@126.com

####导语:

AOP为Aspect Oriented Programming的缩写。 意为:面向切面编程。将日志记录,性能统计,安全控制,事务处理,异常处理等代码从业务逻辑代码中划分出来,通过对这些行为的分离,将它们独立到非指导业务逻辑的方法中,进而改变这些行为的时候不影响业务逻辑的代码。

##一:认识Aop

在日常的编程任务中,很多的代码都是进行一些通用的功能(日志、检测、一层处理等等),然后代码都是机械般的复制粘贴,实际上的业务逻辑代码只占不多的份额。那么,aop能更好的组织通用的代码、然后以标记的方式让某个方法切入,使得业务逻辑和通用代码分离,使其互不影响。

###使用Aop的优点

  • 容易扩展新的切面。
  • 业务逻辑与切面逻辑解耦合。
  • 对修改封闭、对扩展开放。

###CleanAop支持语言 C#

###版本历史 ####当前版本:v1.0.0

  • v1.0.0:框架搭建完成、支持同步异步、提供Demo切面(错误捕获,log,时间记录)、前后切面选择。

###哪里下载?

  1. github地址
  2. 网盘下载

###Demo测试案例

  1. 多切面、同步

    [TryCatchAttrubute]
    [LogAopAttrubute]
    [TimeAop]
    public virtual void DoWord()
    {
        throw new Exception("错误测试");
        Debug.WriteLine("123");
    }
    

    结果:

    开始捕捉异常([TryCatchAttrubute])
    开始执行([LogAopAttrubute])
    2015/11/5 0:47:19([TimeAop])
    错误测试(异常捕获处理)
    执行中([LogAopAttrubute])
    执行结束,Void DoWord()方法([LogAopAttrubute])
    2015/11/4 23:47:19	[TimeAop])
    
  2. 多切面、异步

     [TryCatchAttrubute]
     [LogAopAttrubute]
     [TimeAop]
     public virtual async Task DoWord()
     {
         await GetValueAsync(1234.5123, 1.01);
         Debug.WriteLine("123");
         throw new Exception("错误测试");
         Debug.WriteLine("123");
     }
    

    结果:

     开始捕捉异常([TryCatchAttrubute])
     开始执行([LogAopAttrubute])
     2015/11/5 1:05:23([TimeAop])
     执行中([LogAopAttrubute])
     123
     处理错误,错误信息为:错误测试([TryCatchAttrubute])
     执行结束,System.Threading.Tasks.Task DoWord()方法([LogAopAttrubute])
     2015/11/5 0:05:23([TimeAop])