Golang TemplateMethod流程控制模板方法示例

Go语言通过接口和组合实现模板方法模式,定义算法骨架并延迟步骤实现。示例中Pipeline结构体封装加载、保存等固定流程,DataProcessor接口允许不同验证与处理逻辑注入,UserProcessor和OrderProcessor分别实现特定行为,执行时根据具体处理器完成差异化处理,从而达到流程复用与扩展目的,符合开闭原则且避免代码重复。

golang templatemethod流程控制模板方法示例

在 Go 语言中,虽然没有像 Java 那样的继承机制来直接实现模板方法模式(Template Method Pattern),但可以通过接口和组合的方式模拟这一行为。模板方法模式属于行为型设计模式,它定义了一个算法的骨架,而将一些步骤延迟到子类中实现。

模板方法的核心思想

模板方法模式适用于多个结构相似的类执行流程一致,但某些具体步骤不同时。通过把共用的流程封装在一个“模板函数”中,让不同的实现去覆盖特定环节。

Go 中的实现方式:

使用接口定义可变步骤结构体包含公共流程(即模板方法)不同实现注入接口实现差异逻辑

示例:构建一个数据处理流程

假设我们有一套通用的数据处理流程:加载数据 → 验证数据 → 处理数据 → 保存结果。其中“加载”和“保存”是固定的,而“验证”和“处理”因场景不同而变化。

立即学习“go语言免费学习笔记(深入)”;

定义接口描述可变行为:

type DataProcessor interface {    Validate(data string) bool    Process(data string) string}

定义模板结构体,包含固定流程:

type Pipeline struct {    processor DataProcessor}

func NewPipeline(p DataProcessor) *Pipeline {return &Pipeline{processor: p}}

// TemplateMethod 是模板方法,定义整个流程func (p *Pipeline) Execute(input string) string {// Step 1: 加载数据(固定)data := "Loaded: " + input

// Step 2: 验证(由实现决定)if !p.processor.Validate(data) {    return "Validation failed"}// Step 3: 处理(由实现决定)result := p.processor.Process(data)// Step 4: 保存(固定)return "Saved: " + result

}

实现两个不同的处理器:

// 用户数据处理器type UserProcessor struct{}

func (u *UserProcessor) Validate(data string) bool {return len(data) > 10}

func (u *UserProcessor) Process(data string) string {return "[User] " + data + " [Processed]"}

// 订单数据处理器type OrderProcessor struct{}

func (o *OrderProcessor) Validate(data string) bool {return contains(data, "Order")}

func (o *OrderProcessor) Process(data string) string {return "[Order] " + data + " [Handled]"}

func contains(s, substr string) bool {return len(s) > len(substr) && (s[len(s)-len(substr):] == substr)}

使用示例:

func main() {    userPipe := NewPipeline(&UserProcessor{})    orderPipe := NewPipeline(&OrderProcessor{})
result1 := userPipe.Execute("user_data_123")result2 := orderPipe.Execute("Order_456")fmt.Println(result1) // Saved: [User] Loaded: user_data_123 [Processed]fmt.Println(result2) // Saved: [Order] Loaded: Order_456 [Handled]

}

关键点说明

解耦流程与实现:模板方法把不变的部分固化,变化的部分通过接口注入,便于扩展新类型而不修改原有代码。

符合开闭原则:对扩展开放(新增处理器),对修改关闭(模板方法不动)。

避免重复代码:多个处理器共享同一执行流程,减少冗余。

基本上就这些。Go 虽无继承,但用接口+组合完全可以优雅地实现模板方法模式,特别适合配置化流程控制场景。

以上就是Golang TemplateMethod流程控制模板方法示例的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1410618.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月16日 03:29:59
下一篇 2025年12月16日 03:30:14

相关推荐

  • 如何在Golang中捕获数据库操作错误_Golang数据库操作错误处理方法汇总

    在Golang中进行数据库操作时,必须始终检查error以确保程序健壮性。1. 每次数据库调用如db.Query、db.Exec等都需判断返回的error,防止因连接失败、超时等问题导致程序崩溃。2. 区分错误类型:sql.ErrNoRows表示查询无结果,可特殊处理;driver.ErrBadCo…

    2025年12月16日
    000
  • Go语言泛型DisjointSets:利用interface{}实现通用性

    本文将详细介绍如何在go语言中,通过巧妙运用`interface{}`类型,将原本针对特定数据类型(如`int64`)实现的disjointsets(不相交集)数据结构进行泛型化改造。通过这种方式,您无需为每种新类型重复编写代码,即可使其支持`string`、`float64`等多种可作为map键的…

    2025年12月16日
    000
  • 如何在Golang中使用Docker Compose搭建服务

    答案:使用Docker Compose可快速搭建Go开发环境,包含Go应用、PostgreSQL等服务。1. 编写Go Web服务并监听3000端口;2. 创建多阶段Dockerfile构建轻量镜像;3. 在docker-compose.yml中定义go-app和postgres服务,配置网络与数据…

    2025年12月16日
    000
  • Golang如何处理指针类型断言与类型转换_Golang指针类型断言详解

    指针类型断言需匹配接口内实际类型,如i.(User)用于提取User,断言成功后应检查指针是否为nil;Go不支持直接指针类型转换,需通过值转换或unsafe包操作;对接口进行断言时必须确保类型完全一致,常见错误是混淆指针与值类型。 在Go语言中,指针类型的类型断言和类型转换是开发中常见但容易出错的…

    2025年12月16日
    000
  • 如何在Golang中优化并发读写操作

    在Go并发编程中,应根据读写比例选择合适同步机制:1. 读多写少时用sync.RWMutex提升吞吐;2. 高频键值操作优先sync.Map;3. 复杂协调采用channel通信避免共享状态;4. 通过限流控制协程数量防止资源耗尽。 在Golang中处理并发读写操作时,性能和数据一致性是关键。直接使…

    2025年12月16日
    000
  • Golang并发编程:深入理解通道(Channel)的死锁机制

    本文深入探讨了Go语言中通道(Channel)的并发通信机制,特别是当不当使用无缓冲通道时可能导致的程序挂起(死锁)问题。通过分析多个发送和接收场景,揭示了通道操作中发送方和接收方必须协同工作的核心原理,并提供了避免死锁的正确实践,帮助开发者构建健壮的并发应用。 在Go语言的并发编程模型中,通道(C…

    2025年12月16日
    000
  • Golang如何使用io.Reader与io.Writer处理数据_Golang io.Reader io.Writer实践详解

    io.Reader和io.Writer是Go语言中处理I/O的核心接口,分别定义了Read(p []byte) (n int, err error)和Write(p []byte) (n int, err error)方法,实现它们的类型可统一进行数据读写操作。通过接口抽象,Go程序能以一致方式处理…

    2025年12月16日
    000
  • 如何在Golang中处理HTTP请求Header_Golang HTTP请求Header处理方法汇总

    答案:Go中通过req.Header.Get读取请求头,w.Header().Set设置响应头,客户端用req.Header.Set添加头,注意大小写不敏感和设置时机。 在Golang中处理HTTP请求的Header是构建Web服务和客户端时的常见需求。无论是读取客户端发送的Header,还是为响应…

    2025年12月16日
    000
  • Golang如何管理Docker容器生命周期

    Go语言通过docker/client包调用Docker API管理容器生命周期,无需shell命令,更安全可控;程序通过HTTP客户端连接/var/run/docker.sock创建Docker客户端实例,并使用WithAPIVersionNegotiation()自动协商API版本;通过Cont…

    2025年12月16日
    000
  • Golang如何实现微服务日志收集与聚合

    使用zap等结构化日志库输出JSON格式日志,包含trace_id和服务名;2. 通过Filebeat采集本地日志文件并发送至Kafka;3. 利用Kafka缓冲后由Logstash处理并存入Elasticsearch;4. 通过Kibana实现日志检索与可视化,结合OpenTelemetry将tr…

    2025年12月16日
    000
  • 如何在Golang中实现文件上传进度显示

    答案:通过自定义ProgressReader包装文件流,在读取时实时统计已上传字节数并回调更新进度,结合multipart上传实现Golang文件上传进度显示。 在Golang中实现文件上传进度显示,关键在于监控上传过程中已发送的数据量。标准的 net/http 包本身不提供进度回调机制,因此需要通…

    2025年12月16日
    000
  • 如何在Golang中配置GOPATH与GOROOT

    正确配置GOROOT与GOPATH是Golang环境搭建的关键。GOROOT指向Go安装目录,通常自动设置;GOPATH为工作目录,存放项目及依赖,默认为~/go。自Go 1.11起推荐使用Go Modules管理依赖,项目无需置于GOPATH/src下,依赖缓存于$GOPATH/pkg/mod。即…

    2025年12月16日
    000
  • 如何在 Go 语言中阻塞主 Goroutine?

    本文介绍了在 Go 语言中阻塞主 Goroutine 的几种方法,重点讲解了使用 sync.WaitGroup 和 select {} 的方式。sync.WaitGroup 适用于需要等待子 Goroutine 完成的情况,而 select {} 则适用于永久阻塞主 Goroutine,让其他 Go…

    2025年12月16日
    000
  • Go语言中JSON解码器处理私有字段的策略与实践

    本文深入探讨了go语言`encoding/json`包在解码json数据时,无法直接映射到结构体私有字段的问题。我们将剖析这一常见陷阱,并提供两种核心解决方案:一是将结构体字段声明为公有,使其可被json解码器访问;二是为结构体实现`json.unmarshaler`接口,以自定义解码逻辑,从而灵活…

    2025年12月16日
    000
  • 如何在Golang中实现文件分块传输

    答案:Golang文件分块传输通过切分文件为小块发送,接收端重组,降低内存占用并提升稳定性。1. 定义FileChunk结构含文件名、序号、总块数、数据及末块标记;2. 发送端按64KB或1MB读取文件块,序列化后通过HTTP/TCP发送;3. 接收端按序写入临时文件或缓存,最后合并;4. 可选CR…

    2025年12月16日
    000
  • 如何在Golang中实现并发安全队列

    使用channel或sync.Mutex实现并发安全队列。1. 带缓冲channel天然支持并发安全,适用于固定容量场景;2. 切片+Mutex可动态扩容,但存在内存拷贝开销;3. 双向链表+Mutex避免数据移动,适合高频操作。根据需求选择方案。 在Golang中实现并发安全队列,核心是保证多个g…

    2025年12月16日
    000
  • Golang如何在函数间共享指针数据

    直接传递指针可实现Go语言中函数间高效共享数据,避免拷贝开销。通过参数传指针、返回指针、全局指针或闭包捕获指针等方式,多个函数能操作同一内存,需注意初始化顺序与并发安全。 在Go语言中,函数间共享指针数据是常见需求,尤其当你希望多个函数操作同一块内存时。直接传递指针就能实现高效、实时的数据共享,避免…

    2025年12月16日
    000
  • 如何在Golang中进行内存使用基准测试

    答案是使用testing包中的b.ReportAllocs()和b.ResetTimer()进行内存基准测试,通过Benchmark函数测量B/op和allocs/op指标,比较不同实现的内存效率,并避免初始化影响与编译器优化,确保结果准确。 在Golang中进行内存使用基准测试,主要依赖标准库中的…

    2025年12月16日
    000
  • Golang如何处理JSON数据序列化与反序列化

    Go语言通过encoding/json包实现JSON序列化与反序列化,使用结构体标签如json:”name”映射字段,omitempty忽略零值,字段需首字母大写以导出;通过json.Marshal将结构体转为JSON字符串,json.MarshalIndent可格式化输出;…

    2025年12月16日
    000
  • Golang如何使用适配器模式解决接口不兼容问题_Golang适配器模式接口兼容实践详解

    适配器模式通过创建适配器结构体将第三方支付接口MakePayment转换为系统统一的Pay接口,使不兼容的接口能够协同工作。1. 定义Payment接口规范;2. 第三方服务ThirdPartyPay提供MakePayment方法;3. ThirdPartyPayAdapter组合ThirdPart…

    2025年12月16日
    000

发表回复

登录后才能评论
关注微信