CLR中的派生类可以在保持智能感知的同时拦截/隐匿父类的方法吗?

| CLR是否可以创建从对象Y继承的对象X,其中 对象Y是对象类型 Y的所有方法均可用于对象X。 对象X的调用者认为他们看到了Y \的所有对象 对象X掩盖了上面的方法,并在运行每个方法之前执行一些“工作” “工作”可能包括计算通话次数或一些任意代码 对象X应该能够处理任何对象(如果它不能处理密封对象则可以) 另一种实现可以使用泛型,其中“ 0”公开包含对象Y的所有方法,事件和属性。     
已邀请:
是。这称为代理对象。 Castle DynamicProxy专为做到这一点而设计。 KrzysztofKoźmic撰写了一篇很棒的教程。 它通过在运行时创建一个对象(在您的方案中为X)来工作,该对象继承自您要代理的对象(对象Y)。您提供了一个实现“ 1”的对象,该对象在调用某些方法时会被调用-在代理生成选项类中指定这些对象。 唯一需要注意的是,您要拦截的方法必须是虚拟的,但是您可以通过将对象包装到另一个提供虚拟方法的代理中来解决此问题(尽管我猜您可能想要代理该对象,因为这样做确实很痛苦)。     
看起来符合您的要求(在调用Y上的方法时运行任意代码)但不符合您的问题(子类策略)的运行时代理的替代方案是使用诸如PostSharp或Afterthought等编译时解决方案的AOP。这种方法使您可以将代码引入已编译程序集中的现有方法中,并执行几乎所有您想做的事情。 PostSharp的工作方式是允许定义描述您要如何修改类的属性(方面)。您可以将这些属性放在方法,类型,程序集等上,并且当PostSharp作为生成后步骤运行时,它将查找这些属性并在已编译的程序集上执行转换。 Afterthought使用属性方案来类似地工作,以标识适用于程序集中类型的修改。但是,Afterthought允许您在一个程序集中指定这些属性/修订并将它们应用于另一个程序集,这样您就可以实际修改目标组件,该目标程序集没有对Afterthought的任何属性或引用,也没有对您要引入到其中的库的引用。我基于社区反馈将此功能添加到Afterthought中,希望能够执行优雅的转换而不建立对AOP工具的依赖(在这种情况下为Afterthought),并且可能在程序集的原始源代码不再可用的情况下。 这是一个使用Afterthought自动输出修改后的类型上每个方法调用的执行时间的示例:
public override void Amend(Method method)
{
    method.Context<Stopwatch>()

        .Before((T instance, string method, object[] parameters)
            => { var s = new Stopwatch(); s.Start(); return s; })

        .After((T instance, string method, Stopwatch stopwatch, object[] parameters)
            => Console.WriteLine(method + \": \" + stopwatch.ElapsedMilliseconds);
}
在这种情况下,每个修改类型的方法都将在每个方法的开头创建一个“ 3”实例,并在每个方法的末尾写出方法的名称和执行时间。     

要回复问题请先登录注册