代理模式在 go 中允许我们创建代理类,该代理类代表并控制对真实对象的访问。它实现了代码复用并允许我们修改或扩展真实对象的行为:定义 subject 接口,描述真实对象的操作。创建 realsubject 对象,实现 subject 接口的具体行为。创建 proxy 代理类,实现 subject 接口。在 proxy 类中,包含对 realsubject 对象的引用。在 proxy 类的 dosomething() 方法中,执行代理逻辑并调用 realsubject 对象的方法。这有助于我们实现代码复用,并允许在不修改真实对象的情况下轻松修改或扩展其行为。
Go 中的代理模式:通过接口实现代码复用
在 Go 中,代理模式是一种设计模式,允许我们创建代表另一个对象的类或结构。代理可以控制对真实对象的访问,并执行额外的操作或修改行为,从而实现代码复用。
代理模式的结构
以下是最简单的代理模式结构:
// Subject 接口定义了真实对象的操作。 type Subject interface { DoSomething() } // RealSubject 是具体实现 Subject 接口的对象。 type RealSubject struct { // 具体行为的实现 } func (rs *RealSubject) DoSomething() { // 真实对象的具体行为 } // Proxy 是代理类,实现 Subject 接口。 type Proxy struct { // 对真实对象的引用 realSubject *RealSubject } func (p *Proxy) DoSomething() { // 代理逻辑 // ... // 调用真实对象的方法 p.realSubject.DoSomething() }
实战案例
考虑一个日志记录系统,我们希望所有日志记录调用都通过一个中心化的日志记录服务。我们可以使用代理模式来实现这一点。
立即学习“go语言免费学习笔记(深入)”;
// 日志记录服务接口 type Logger interface { Log(msg string) } // 真实日志记录服务 type RealLogger struct {} func (rl *RealLogger) Log(msg string) { // 日志记录的实际实现 } // 日志记录代理 type LoggerProxy struct { // 对真实日志记录服务的引用 realLogger Logger } func (lp *LoggerProxy) Log(msg string) { // 代理逻辑:添加时间戳 ts := time.Now().Format("2006-01-02 15:04:05") msg = fmt.Sprintf("%s: %s", ts, msg) // 调用真实日志记录服务的方法 lp.realLogger.Log(msg) } func main() { // 创建真实日志记录服务 realLogger := &RealLogger{} // 创建代理 loggerProxy := &LoggerProxy{realLogger} // 使用代理记录日志 loggerProxy.Log("Hello world!") }
在这种情况下,LoggerProxy 充当 RealLogger 的代理。它负责在日志记录信息中添加时间戳,而无需修改 RealLogger 本身。这使我们能够轻松地将日志记录行为添加到我们的应用程序中,而不必重新编写每个需要日志记录的函数。