最近在做RPC的时候遇到了一点问题,接口I的调用方在进程A,而实现方在进程B。那么要完成进程A中的操作,必然要在进程A生成接口I的动态代理。怎么办呢?这里使用DispatchProxy来进行实现
DispatchProxy是一个抽象类,使用方法非常简单。只需要继承这个类,重写他的Invoke方法,这里我们可以从参数获得代理被调用方法的MethodInfo以及其传入的参数。这里我们先试着打印他的方法名称
public class ADispatchProxy : DispatchProxy
{
protected override object Invoke(MethodInfo targetMethod, object[] args)
{
Console.WriteLine(targetMethod.Name);
return null;
}
}
接着我们考虑接口IA
public interface IA
{
void Foo(string a);
}
试着创建一个IA的代理,这里用到了静态方法DispatchProxy.Create<IA, ADispatchProxy>()
class Program
{
static void Main(string[] args)
{
var a = DispatchProxy.Create<IA, ADispatchProxy>();
a.Foo(</

本文介绍了如何在C#中利用DispatchProxy生成动态代理,以解决跨进程RPC调用的问题。通过继承DispatchProxy,重写Invoke方法,可以捕获接口调用的详细信息。示例展示了如何创建IA接口的代理并结合简单的容器实现接口注入。最终,动态代理在调用时能够获取到实际调用的实例方法,为实现进程间通信(IPC)和RPC奠定了基础。

1067

被折叠的 条评论
为什么被折叠?



