代理模式在Go中通过组合与函数封装实现,核心是代理对象持有真实对象引用并在调用前后插入控制逻辑;支持结构体嵌入、函数装饰器及接口委托三种方式,适用于鉴权、懒加载、熔断等场景。
代理模式在 Go 中不依赖继承或接口强制约束,而是通过组合与函数封装自然实现——核心是让代理对象持有真实对象引用,并在调用前后插入控制逻辑。
Go 没有传统面向对象的“方法重写”,但可通过嵌入(embedding)+ 显式方法定义轻松模拟代理行为。关键在于:代理结构体包含真实对象字段,且对外暴露相同方法签名,在方法体内决定是否调用、何时调用、如何包装结果。
DoWork())*RealSubject
Proxy.DoWork() 中添加权限检查、日志、缓存判断等前置/后置逻辑,再有条件地调用 r.DoWork()
当只需拦截单一方法或临时增强行为时,可直接用函数值作为代理。Go 的函数是一等公民,天然支持装饰器风格。
type Operation func() error
func WithLogging(op Operation) Operation,返回新函数,在调用 op() 前后打印日志WithAuth(WithLogging(realOp))
若需灵活切换真实对象或统一抽象,可先定义接口(如 Subject),让 RealSubject 和 Proxy 都实现它。这样上层代码只依赖接口,代理可透明介入。
Proxy 实现同一接口,内部委托给具体实例
便于单元测试中注入 mock代理的价值在于解耦横切关注点。例如:
ctx.Value("user").(*User).HasRole("admin"),不满足则直接返回错误Proxy 字段初始为 nil,首次调用时才初始化真实对象并缓存