Go语言通过高阶函数实现装饰器模式,以函数包装函数的方式扩展功能而不修改原逻辑。1. 定义统一函数类型如HandlerFunc;2. 编写基础函数如Hello;3. 创建装饰器函数WithLogging添加日志;4. 实现WithTiming统计耗时;5. 支持链式组合如WithLogging(WithTiming(Hello)),执行顺序由外向内;6. 可针对HTTP场景封装HTTPLogger等通用装饰器。该模式依赖类型匹配与调用顺序,适用于日志、中间件等场景。

在Go语言中,虽然没有像Python那样的
@decorator
要实现装饰器,先定义统一的函数签名类型。比如处理HTTP请求的处理器:
type HandlerFunc func(string) string
这个函数接收一个字符串参数,返回一个字符串结果。你可以根据实际场景替换成
http.HandlerFunc
先写一个简单的业务函数:
立即学习“go语言免费学习笔记(深入)”;
func Hello(name string) string {
return "Hello, " + name
}
</font>
写一个装饰器函数,接收原函数,返回一个功能增强的新函数:
func WithLogging(fn HandlerFunc) HandlerFunc {
return func(name string) string {
fmt.Printf("调用函数,参数: %s\n", name)
result := fn(name)
fmt.Printf("函数返回: %s\n", result)
return result
}
}
</font>
这个装饰器在调用前后打印日志,原函数逻辑不受影响。
可以再写一个统计执行时间的装饰器:
func WithTiming(fn HandlerFunc) HandlerFunc {
return func(name string) string {
start := time.Now()
result := fn(name)
fmt.Printf("执行耗时: %v\n", time.Since(start))
return result
}
}
</font>
多个装饰器可以链式调用:
handler := WithLogging(WithTiming(Hello))
result := handler("Alice")
</font>
执行顺序是从外到内:先日志 → 再计时 → 调用Hello。
如果想支持不同签名的函数,可以用
interface{}http.HandlerFunc
func HTTPLogger(next http.HandlerFunc) http.HandlerFunc {
return func(w http.ResponseWriter, r *http.Request) {
fmt.Printf("[%s] %s\n", r.Method, r.URL.Path)
next(w, r)
}
}
</font>
在HTTP服务中这样使用:
http.HandleFunc("/hello", HTTPLogger(func(w http.ResponseWriter, r *http.Request) {
fmt.Fprintln(w, "Hello World")
}))
</font>
Go的装饰器模式依赖高阶函数,通过传入函数并返回新函数来实现功能增强。这种方式清晰、灵活,适合中间件、日志、监控等场景。基本上就这些,不复杂但容易忽略的是类型匹配和调用顺序。
以上就是Golang装饰器模式写法 函数包装扩展功能的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号