建造者设计模式go实现尝试

文章目录


前言

本文章尝试使用go实现"建造者"。


代码

go 复制代码
package main

import (
	"fmt"
)

// 产品1。可以有不同的毫无相关的产品,这里只举一个
type Product1 struct {
	parts []string
}

// 产品1逻辑。打印组成产品的部分
func (p *Product1) ListParts() {
	parts := p.parts
	length := len(parts)
	fmt.Print("Product parts: ")
	for i := 0; i < length; i++ {
		if i == length-1 {
			fmt.Print(parts[i])
		} else {
			fmt.Print(parts[i], ", ")
		}
	}
	fmt.Println()
	fmt.Println()
}

// 建造者接口提供分别创建所有产品部分的方法。这里举例产品最多有三个部分。
// 返回IBuilder接口,以便链式调用
// 由于组建完成后要返回的产品各式各样,比如产品1、2、3......,可能没有相同的接口,这里就不提供返回产品的方法了
type IBuilder interface {
	ProducePartA() IBuilder
	ProducePartB() IBuilder
	ProducePartC() IBuilder
}

// 具体建造者1。对应返回产品1,这里只举一个。按不同配置需求返回的产品1也不尽相同
type ConcreteBuilder1 struct {
	product Product1
}

func (cb *ConcreteBuilder1) Reset() {
	cb.product = Product1{}
}

func (cb *ConcreteBuilder1) ProducePartA() IBuilder {
	cb.product.parts = append(cb.product.parts, "PartA1")
	return cb
}

func (cb *ConcreteBuilder1) ProducePartB() IBuilder {
	cb.product.parts = append(cb.product.parts, "PartB1")
	return cb
}

func (cb *ConcreteBuilder1) ProducePartC() IBuilder {
	cb.product.parts = append(cb.product.parts, "PartC1")
	return cb
}

// 获取产品1。不同产品可能没有共同的实现接口,故返回类型为具体产品类
func (cb *ConcreteBuilder1) GetProduct() Product1 {
	result := cb.product
	cb.Reset()
	return result
}

// go语言使用普通函数实现构造函数
func NewConcreteBuilder1() *ConcreteBuilder1 {
	cb := ConcreteBuilder1{}
	cb.Reset()
	return &cb
}

// 主管。接收建造者,并根据配置需求要求建造者创建包含部分组件的对象
type Director struct {
	builder IBuilder
}

func (d *Director) SetBuilder(builder IBuilder) {
	d.builder = builder
}

func (d *Director) BuildMinimalViableProduct() {
	d.builder.ProducePartA()
}

func (d *Director) BuildFullFeaturedProduct() {
	d.builder.ProducePartA().ProducePartB().ProducePartC()
}

// 客户端代码
func clientCode(d *Director) {
	builder := NewConcreteBuilder1()
	d.SetBuilder(builder)
	fmt.Println("Standard basic product:")
	d.BuildMinimalViableProduct()

	p := builder.GetProduct()
	p.ListParts()

	fmt.Println("Standard full featured product:")
	d.BuildFullFeaturedProduct()

	p = builder.GetProduct()
	p.ListParts()

	// 不通过主管也能自定义创建产品
	fmt.Println("Custom product:")
	builder.ProducePartA()
	builder.ProducePartC()
	p = builder.GetProduct()
	p.ListParts()
}

func main() {
	clientCode(&Director{})
}

结果

复制代码
Standard basic product:
Product parts: PartA1

Standard full featured product:
Product parts: PartA1, PartB1, PartC1

Custom product:
Product parts: PartA1, PartC1

总结

新人设计模式理解,望大家多多指点。

相关推荐
水淹萌龙2 小时前
玩转 Go 表达式引擎:expr 实战指南
开发语言·后端·golang
Yeats_Liao3 小时前
Go Web 编程快速入门 07.4 - 模板(4):组合模板与逻辑控制
开发语言·后端·golang
wyzqhhhh3 小时前
前端常见的设计模式
前端·设计模式
m0_748233644 小时前
C++开发中的常用设计模式:深入解析与应用场景
javascript·c++·设计模式
Wind哥5 小时前
设计模式23种-C++实现
开发语言·c++·windows·设计模式
闲人编程6 小时前
Python设计模式实战:用Pythonic的方式实现单例、工厂模式
开发语言·python·单例模式·设计模式·工厂模式·codecapsule·pythonic
nexttake7 小时前
5.go-zero集成gorm 和 go-redis
开发语言·后端·golang
QX_hao13 小时前
【Go】--闭包
开发语言·golang
御承扬15 小时前
编程素养提升之EffectivePython(Builder篇)
python·设计模式·1024程序员节
脚踏实地的大梦想家18 小时前
【Go】P8 Go 语言核心数据结构:深入解析切片 (Slice)
开发语言·数据结构·golang