标签:response 对象 透明代理 sed 技术 问题 override 构造器 creat
AOP思想是为了处理应用程序中掺杂的一些非问题域相关的代码片段,比如 日志记录,异常处理等一些跨问题域的通用代码片段。AOP的重点在于提供一种处理机制将应用程序分离成多个块,主要是 问题域块和通用处理方法块。
一 .问题域处理不用一些无关处理代码污染。
二.通用处理代码重用度高
一.透明代理 remoting技术在core中不被支持。
原理:AOP实现的是对方法的拦截调用,方法本质上就是CLR堆栈上进行内存转换,调用方通过方法表找到方法堆栈地址,按照参数格式把参数压入堆栈,方法处理堆栈参数,重写堆栈标识处理结果。
CLR提供了一种方法转消息的能力---透明代理;透明代理是由CLR创建的一种特别对象,它的存在只是为了将方法调用转成消息。System.Runtime.remoting 下定义了消息处理的众多接口。
透明代理对象非常特殊,不能继承或者通过构造器创建透明代理对象,它和真实代理存在一一对应关系,只能通过真实代理的方法得到透明代理。
通过透明代理调用的方法,CLR会截获并进行检查,满足跨域调用就会将方法堆栈转换成消息对象,并转发到真实代理对象上进行处理。
实现步骤: 1.定义真实代理
public class ExcetionProxy : RealProxy { /// <summary> /// 代理执行的真实对象 /// </summary> readonly MarshalByRefObject mtarget; public ExcetionProxy(MarshalByRefObject target, Type t) : base(t) { this.mtarget = target; } /// <summary> /// 方法消息截获 /// </summary> /// <param name="msg"></param> /// <returns></returns> public override IMessage Invoke(IMessage msg) { IMethodCallMessage call= (IMethodCallMessage)msg; Console.Write(" 方法执行之前"+ call.MethodName+"\n"); try { IMessage response = RemotingServices.ExecuteMessage(mtarget, call);//执行代理方法 return response; } catch (Exception ex) { throw; } finally { Console.Write(" Excetion Process Success"); } } }
2. 代理的透明转换
真实处理对象必须继承 MarshalByRefObject,MarshalByRefObject作用是对对象打标签,表示对象方法不能够被CLR在编译时做优化处理.
public class MyExcObject : MarshalByRefObject { public static MyExcObject Create() { MyExcObject target = new MyExcObject(); ExcetionProxy rp = new ExcetionProxy(target, typeof(MyExcObject)); return (MyExcObject)rp.GetTransparentProxy(); } private MyExcObject() { } public Double Add(double x,double y) { return x + y; } }
标签:response 对象 透明代理 sed 技术 问题 override 构造器 creat
原文地址:http://www.cnblogs.com/RunStone/p/7355251.html