理解c#中的代理模式
本文关键字:代理 模式 理解 | 更新日期: 2023-09-27 18:17:53
假设我试图通过其他类访问一个类的方法,就像这样
class SuperClass
{
public interface ISubject
{
void Print();
}
private class Subject : ISubject
{
public void Print()
{
Console.WriteLine("this is a print");
}
}
public class Proxy {
ISubject subject;
public void CallOtherMethod() {
subject = new Subject();
subject.Print();
}
}
}
class Client: SuperClass
{
static void Main() {
Proxy proxy = new Proxy();
proxy.CallOtherMethod();
}
}
这被称为代理类吗?或者它是否要求有一个接口作为引用,然后我们必须调用该方法?例如:
class SuperClass
{
public interface ISubject
{
void Print();
}
private class Subject : ISubject
{
public void Print()
{
Console.WriteLine("this is a print");
}
}
public class Proxy : ISubject
{
ISubject subject;
public void Print()
{
subject = new Subject();
subject.Print();
}
}
}
class Client : SuperClass
{
static void Main()
{
ISubject proxy = new Proxy();
proxy.Print();
}
}
通常,代理模式的目标是拦截。也就是说,捕捉对某种类型的一些(或全部)方法的调用,并在实际调用之前/之后执行一些操作。为了实现这一点,代理必须从目标类型继承。
例如:public class Subject
{
public virtual void Print()
{
Console.WriteLine("this is a print");
}
}
public class SubjectProxy : Subject
{
public override void Print()
{
Console.Write("Before calling base.Print()");
base.Print();
Console.Write("After calling base.Print()");
}
}
现在,当你在代码中的某个点期待Subject
时,你可能实际上得到了SubjectProxy
,但仍然将其视为Subject
:
public Subject GetSubject()
{
return new SubjectProxy();
}
Subject subject = GetSubject();
subject.Print(); // would use the proxied method
(这并不是说实现拦截的唯一方法是通过继承。我认为有代理风格,使用变化的组成/装饰来实现这一点)