Unity The Assembly Matching Rule
Unity的拦截策略中提供了程序集匹配规则,我们可以对于属于某个特定程序集的类型附加CallHandler。看一个简单的示例:
1 public class MyObject 2 { 3 public virtual void DoWork() 4 { 5 6 } 7 } 8 9 public class MyCallHandler : ICallHandler 10 { 11 #region ICallHandler Members 12 13 public IMethodReturn Invoke(IMethodInvocation input, GetNextHandlerDelegate getNext) 14 { 15 return getNext()(input, getNext); 16 } 17 18 public Int32 Order { get; set; } 19 20 #endregion 21 } 22 23 public class MyCallHandler2 : ICallHandler 24 { 25 #region ICallHandler Members 26 27 public IMethodReturn Invoke(IMethodInvocation input, GetNextHandlerDelegate getNext) 28 { 29 return getNext()(input, getNext); 30 } 31 32 public Int32 Order { get; set; } 33 34 #endregion 35 } 36 37 IUnityContainer unityContainer = new UnityContainer(); 38 39 unityContainer.LoadConfiguration(); 40 unityContainer.Configure<Interception>() 41 .AddPolicy(“AssemblyPolicy”) 42 .AddMatchingRule(new AssemblyMatchingRule(Assembly.GetEntryAssembly())) 43 .AddCallHandler<MyCallHandler>() 44 .AddCallHandler<MyCallHandler2>(); 45 46 unityContainer.RegisterType<MyObject>( 47 new Interceptor<VirtualMethodInterceptor>(), 48 new AdditionalInterface<INotifyPropertyChanged>(), 49 new InterceptionBehavior<PolicyInjectionBehavior>() 50 ); 51 52 MyObject myObject = unityContainer.Resolve<MyObject>(); 53 54 myObject.DoWork();
AssemblyMatchingRule的构造函数允许传递字符或者Assembly信息。上面的示例传递了当前AppDomain入口的EntryAssembly,MyObject类型属于这个Assembly中,所以MyCallHandler和MyCallHandler2在DoWork函数调用时都会被依次调用。同样上面的代码也可以通过配置文件定义:
<unity xmlns=”http://schemas.microsoft.com/practices/2010/unity”> <sectionExtension type=”Microsoft.Practices.Unity.InterceptionExtension.Configuration.InterceptionConfigurationExtension, Microsoft.Practices.Unity.Interception.Configuration” /> <assembly name=”mscorlib, 2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089″ /> <assembly name=”UnityTest6″ /> <namespace name=”System.ComponentModel” /> <namespace name=”UnityTest6″ /> <container> <extension type=”Interception” /> <interception> <policy name=”AssemblyPolicy”> <matchingRule name=”AssemblyMatchingRule” type=”AssemblyMatchingRule”> <constructor> <param name=”assemblyName” value=”UnityTest6″ /> </constructor> </matchingRule> <callHandler name=”MyCallHandler” type=”MyCallHandler” /> </policy> </interception> <register type=”MyObject”> <interceptor type=”VirtualMethodInterceptor” /> <addInterface type=”INotifyPropertyChanged” /> <interceptionBehavior type=”PolicyInjectionBehavior” /> </register> </container> </unity>
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· DeepSeek 开源周回顾「GitHub 热点速览」
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· AI与.NET技术实操系列(二):开始使用ML.NET
· 单线程的Redis速度为什么快?