.NET :消息与AOP(一)

方法调用与消息

如果一个目标对象委托给一个真实代理实例,那么所有对对应的透明代理的方法调用都会经过一个消息转换与反转换的过程,而
正是将方法调用转换为消息后,我们才有机会实现预(后)处理,这样更进一步的结果是 ==》 实现所谓的AOP。

1. 真实代理:从RealProxy派生,最主要的是复写Invoke方法。Invoke方法的主要职能是为截获方法调用加上预(后)处理,以
此来实现AOP。
(1) 一种真实代理类型就表示一种特定的预(后)处理,如果一个类希望自己的公共方法被外界调用时进行适当的预处理或后处理,
那么该类可以将自己的实例委托给有此预(后)处理功能的真实代理。
(2) 真实代理实例与透明代理实例是一一对应的。不存在透明代理的类,但是却可以从真实代理实例得到透明代理。
(3) 透明代理:将方法调用转换为消息(实际被转换的是堆栈帧)。针对透明代理调用目标对象的方法,会被最终转发到目标对象
上。在使用层面上来看,可以将透明代理当作目标对象本身。
(4) Stack Builder Sink :将消息转换为方法调用,并返回调用结果给代理,再由代理将结果转为响应消息通过RPC传递,然后
在将响应消息转换为调用后的堆栈,这样原调用方便可得到调用结果。
(5) 针对不同的预(后)处理,可以定义不同的真实代理类型。

2. 如果一个类(比如class Example)希望外界调用它的公共方法(包括ctor)时,通过代理来完成(主要目的是实现某种特定
的预/后处理),那么有两种方法来实现:
(1) 将Example以工厂方法的模式实现,这样在其static Instance方法中,可以将一个新实例的引用委托给一个实现特定预处理和
后处理的真实代理。接着将该代理的透明代理强制转换为该类引用,并返回它。此处情况下,真实代理类型仅需从RealProxy一
个类派生。
(2) 通过代理特性(一种特殊的真实代理)实现。
首先,代理特性类型必须从ProxyAttribute派生,此时有两个方法需要复写,一个是Invoke方法,另一个是CreateInstance方法。
u Example必须ContextBoundObject派生,即Example必须为一个上下文绑定对象,另外,为Example类加上代理特性。
注意,对不是从ContextBoundObject类派生的类实施上下文特性(即代理特性)。
u 在该情况下,对象激活(即new Example时)被分为两个阶段,首先调用真实代理的CreateInstance方法,生成一个未初始化的对象;
接着在将ctor转发给真实代理的Invoke方法。

注意:(1)和(2)的比较:(1)中将目标对象委托给代理是Example自己的职责,而(2)中把该职责转移到代理中去了。

1. 上下文特性修饰一个类,以后每次new这个类产生对象时,都将对象放入相应的上下文中。
2. 上下文特性与上下文属性通常是一一对应的。
3. 上下文特性在创建时将上下文属性添加到上下文中,更确切说,是这样的,上下文特性检查当前上下文中
是否存在要添加的属性,并且存在的属性值与要添加的属性值是否相等,如果两者都满足,则直接在该上
下文中创建新实例。否则,上下文特性将要求对象ctor创建一个新的上下文包含所要添加的属性。
4. 一个上下文可以包含多个不同的上下文属性,每一组确定的上下文属性值即可确定一个上下文。

5. 消息接收器本身可以作为任何种类的接收器,关键是看上下文属性将其安排为何种接
收器(如,信使接收器,服务器上下文接收器)

上下文属性向消息接收器链中插入消息接收器的两种方式:
(1)仅仅发布公共属性 P240
(2) 实现某些类型的接收器接口(如信使接收器),然后将某个(些)消息接收器对象确认为对应的接收器接口类型。P349

注意:上下文(context)是存在于当前应用域中的,用于将该上下文中的属性转换为接收器插入到该上下文中的对象的方法调用过程中。
而调用上下文(call context)是存在于消息接收器链中的,用于在链中传递信息。

时间: 2024-11-03 01:37:21

.NET :消息与AOP(一)的相关文章

.NET :消息与AOP(二)

using System;using System.Runtime.Remoting ;using System.Runtime.Remoting.Services ;using System.Runtime.Remoting.Activation ;using System.Runtime.Remoting.Proxies ;using System.Runtime.Remoting.Messaging ; /* 本程序说明了截获是如何进行的,以及真实代理和透明代理之间的关系及交互.*/nam

J2EE中使用Spring AOP框架和EJB组件

j2ee 快速发展的开发人员社区.对各种后端技术(包括JMS.JTA.JDO.Hibernate.iBATIS等等)的支持,以及(更为重要的)非侵入性的轻量级IoC容器和内置的AOP运行时,这些因素使得Spring Framework对于J2EE应用程序开发十分具有吸引力.Spring托管的组件(POJO)可以与EJB共存,并允许使用AOP方法来处理企业应用程序中的横切方面--从监控和审计.缓存及应用程序级的安全性开始,直到处理特定于应用程序的业务需求. 本文将向您介绍Spring的AOP框架在

借助 AOP 为 Java Web 应用记录性能数据

作为开发者,应用的性能始终是我们最感兴趣的话题之一.然而,不是所有的开发者都对自己维护的应用的性能有所了解,更别说快速定位性能瓶颈并实施解决方案了. 2015 年北京 Velocity 的赞助商大多从事 APM 领域,提供性能剖析.可视化甚至优化的解决方案.这些厂商的产品看起来能够很好地帮助中小企业的开发者解决应用性能上的缺陷,但是这些产品几乎都有着一个致命的缺陷:极强的侵入性. 开发者需要在业务生产代码中嵌入 APM 厂商提供的埋点代码,才能够使用 APM 厂商提供的 SaaS 服务.在瞬息万

C# AOP微型框架实现(一)

  在前面的系列文章中,我介绍了消息.代理与AOP的关系,这次将我自己实现的一个AOP微型框架拿出来和大家交流一下. AOP的最基本功能就是实现特定的预处理和后处理,我通过代理实现了此微型框架. 先来看看构成此微型框架的4个.cs文件. 1.CommonDef.cs 用于定义最基本的AOP接口 /************************************* CommonDef.cs ************************** using System;using Syst

AOP@Work: 用Contract4J进行组件设计-用契约式设计和AspectJ改进软件

简介:契约式设计(Design by Contract)是切实可行的技术,可以阐明组 件 设计的细节.为客户记录正确的组件用法,并用编程的方式测试组件使用的顺应 性(compliance).在 AOP@Work 的最后一篇中,Dean Wampler 介绍 了 Contract4J,这是契约式设计的工具,它用 Java 5 标注 (annotation)指定合约,并在运行时用 AspectJ 方面计算合约.在成为 AOP 工具包中新增的一个举足轻重的工具的同时,Contract4J 迎合了面向方

AOP的两个应用(下)

AOP的两个应用:实体集更新(DateEntityListUpdate).延迟加载(LazyLoad)(下) LazyLoadableSink类 //******************************************************************* // 模块:实现延迟载入的消息接收器 // 日期:2009-9-19 14:08:58 // 作者:Faib // 版权:Copyright Faib Studio 2009 // 官网:http://www.fa

AOP的两个应用(上)

AOP的两个应用:实体集更新(DateEntityListUpdate).延迟加载(LazyLoad)(上) 在FaibClass.Data中,有两个AOP的应用,它们分别是实体集更新(DateEntityListUpdate).延迟加载 (LazyLoad),目前的DataEntity继承于ContextBoundObject,刚刚从网上看到ContextBoundObject的损耗非常大,但自己测试了一下,应该说影响不是很大,所以暂时不打算使用静态注入了. 注,两个AOP都采用Attribu

C# 用Attribute实现AOP事务 [C# | AOP | Attribute | ContextAttribute | IContributeObjectSink | IMessageSink ]

前言      使用Attribute来实现方法级别事务一直是我的梦想,浅谈Attribute [C# | Attribute | DefaultValueAttribute]有体现我的无奈,Attribute确实是真真切切的非侵入式的东西(其实我是想侵入的: ) ),前有DUDU的Attribute在.net编程中的应用系列文章,但是总是离想象和需求有那么点出入,通过三天的努力,Google的陪伴,下面和大家一起分享我这三天的成果 用Attribute实现AOP事务 吧!   致谢文章    

AOP 你想干什么 IOC 你服务什么

前言: 记得N年前,就听过AOP,曾扫过几篇文章,不过看不懂,还是N年前,面试被问到AOP的切面,还是不懂! 中秋之假,有点闲,在博客园里搜了下AOP看了看,试图看懂些许文章,可惜文章都说的太中规中矩,没发现一篇能浅显看的易懂的.   AOP,全称Aspect Oriented Programming,中文名称叫面向方面编程,也叫面向切面编程.   AOP,你出来的意图? 借用一图: 不就为解耦,分离出权限/操作日志/异常/事务等模块出来?   这里贴一段我项目中的代码,最常见的修改密码: