AOP实现原理

本文深入探讨了AOP(面向切面编程)的两种主要实现方式:AspectJ静态代理和AOP动态代理(包括JDK动态代理和CGLIB动态代理)。详细解析了它们的工作原理,如何在编译阶段或运行时生成代理对象,以及在不同场景下选择合适代理方式的考量。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

AOP实现共有两种方式,即AspectJ静态代理 和 AOP动态代理

一、AspectJ静态代理

1、AspectJ是静态代理的增强,使用AspectJ编译时增强实现AOP,它会在编译阶段将AspectJ织入java字节码中,需要特定的编译器

2、代理对象和目标对象实现共同的接口,并且代理对象持有目标对象的引用

二、AOP动态代理JDK动态代理 和 CGLIB动态代理

Spring AOP是动态代理,AOP框架不会去修改字节码,而是在内存中临时为方法生成一个AOP对象,这个AOP对象包含了目标对象的所有方法,并且在特定的切点做了增强处理,并回调原对象的方法

2.1、JDK动态代理

1、通过反射来接收被代理的类,并且要求被代理的类必须实现一个接口

2、JDK动态代理的核心是实现 InvocationHandler(invoke方法)接口和 Proxy

2.2、CGLIB动态代理

1、如果目标类没有实现接口,AOP会选择使用CGLIB来动态代理目标类

2、CGLIB(Code Generation Library)是一个代码生成的类库,可以在运行时动态的生成某个类的子类(继承关系)

3、通过继承的方式做动态代理,如果目标类被final修饰,它是无法使用CGLIB做动态代理的

### C# 中 AOP实现原理 AOP(面向切面编程)的核心目标是将横切关注点(如日志记录、性能监控、安全性验证等)从业务逻辑中分离出来,形成独立的模块化单元——即切面(Aspect),并通过特定的方式将其注入到应用程序的关键位置上。以下是关于 AOP 实现原理的具体说明: #### 1. 切面的概念与作用 切面是指封装了横切关注点的功能模块。在实际应用中,切面通常由以下几个部分组成: - **切入点(Pointcut)**:定义程序中需要被拦截的位置集合。例如方法调用前、异常抛出时等。 - **通知(Advice)**:指定切入点击发生的行为动作。常见的有前置通知(Before Advice)、后置通知(After Advice)、环绕通知(Around Advice)等。 这种设计允许开发者专注于核心业务逻辑的同时,还能灵活地扩展额外功能而无需修改原有代码结构。 #### 2. 动态代理 vs 静态织入 AOP 可以通过两种主要的技术手段来实现其工作机制:动态代理和静态织入。 ##### (a) 动态代理 动态代理是在运行时期间创建代理对象并附加行为的方法之一。这种方式不需要改变原始类文件本身,在每次请求到达之前都会先经过中间层处理后再转发给真实的目标服务实例完成最终操作过程[^2]。 示例代码如下所示: ```csharp public class LoggingInterceptor : IInterceptor { public void Intercept(IInvocation invocation) { Console.WriteLine($"Method {invocation.Method.Name} is about to be called."); try { invocation.Proceed(); // Proceed with the original method call. Console.WriteLine($"Method {invocation.Method.Name} completed successfully."); } catch (Exception ex) { Console.WriteLine($"An error occurred while executing {invocation.Method.Name}: {ex.Message}"); throw; } } } ``` ##### (b) 静态织入 相比之下,静态织入则会在编译阶段或者加载字节码之后直接修改现有的二进制数据流内容以便加入新的指令序列达到增强目的效果[^1]。这种方法的优点在于性能较高因为所有的改动都已经提前做好所以不会增加任何额外开销;缺点则是灵活性较差一旦部署完毕就很难再做调整除非重新打包发布新版本才行。 下面是一个简单的例子展示了如何使用 PostSharp 来声明一个自定义属性用于跟踪方法执行时间: ```csharp [Serializable] public sealed class TraceAttribute : OnMethodBoundaryAspect { private Stopwatch _stopwatch; public override void OnEntry(MethodExecutionArgs args) { base.OnEntry(args); this._stopwatch = new Stopwatch(); this._stopwatch.Start(); } public override void OnExit(MethodExecutionArgs args) { base.OnExit(args); this._stopwatch.Stop(); Debug.WriteLine( $"Executing [{args.Method}] took {_stopwatch.ElapsedMilliseconds} ms"); } } // Usage Example: [Trace] public void SomeBusinessLogic() { Thread.Sleep(50); // Simulate work being done here... } ``` 以上就是有关于 AOP 原理及其工作流程的一个概括总结。可以看出无论是采用哪种具体实施方案都离不开对于 Join Points 和 Advices 这两个基本要素的理解掌握以及合理运用才能真正发挥好这一强大工具所带来的价值所在! ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值