5

我正在尝试通过 a 处理泛型方法的调用RealProxy,但我似乎无法找到有关在截获的方法调用中使用的泛型参数的实际类型的信息。代码摘录:

    public override IMessage Invoke(IMessage msg)
    {
        ...
        string methodName = (string)msg.Properties["__MethodName"];
        Type[] parameterTypes = (Type[])msg.Properties["__MethodSignature"];
        object[] args = (object[])msg.Properties["__Args"];

        MethodInfo method = typeToProxy.GetMethod(methodName, parameterTypes);
        ...

假设我正在代理一个接口,例如

interface IFactory
{
   TService Create<TService>()
}

当我打电话给代理

proxied.Create<MyClass>()

我希望能够找出泛型参数的类型MyClass。这可以通过RealProxy吗?

4

2 回答 2

6

我推荐你阅读一篇关于 RealProxy的优秀MSDN 文章。除其他外,它还介绍了MethodCallMessageWrapper这可以省去您直接对Properties字典工作的麻烦。从后者你可以得到MethodBase,它又包含通用参数:

internal class MyProxy : RealProxy
{
   private object m_instance;    
   private MyProxy( object instance ) : base( typeof( IFactory) )
   {
      m_instance = instance;
   }

  public override IMessage Invoke( IMessage message )
  {
     IMethodCallMessage methodMessage =
        new MethodCallMessageWrapper( (IMethodCallMessage) message );

     // Obtain the actual method definition that is being called.
     MethodBase method = methodMessage.MethodBase;

     Type[] genericArgs = method.GetGenericArguments(); //This is what you want

     return new ReturnMessage(...);
  }

  ...
}
于 2010-10-31T09:27:08.303 回答
3

对于方法调用,IMessage参数应该是 a IMethodMessage,它有一个MethodBase属性:

public override IMessage Invoke(IMessage message)
{
    IMethodMessage methodMessage = message as IMethodMessage;
    if (methodMessage != null)
    {
         MethodBase method = methodMessage.MethodBase;
         Type[] genericArgs = method.GetGenericArguments();

         ...
    }
    else
    {
        // not a method call
    }
}
于 2010-10-31T10:49:12.223 回答