Go设计模式

创建型模式

工厂模式

package main

import "fmt"

type vehicle interface {
	run()
}

type Factory struct {}

func (f *Factory) GetVehicle(v string) vehicle {
	switch v {
	case "CAR":
		return new(car)
	case "BIKE":
		return new(bike)
	default:
		return new(car)
	}
}

type car struct {}

func (c *car) run() {
	fmt.Println("car is running")
}

type bike struct {}

func (b *bike) run() {
	fmt.Println("bike is running")
}

func main() {
	f := new(Factory)
	b := f.GetVehicle("BIKE")
	b.run()
}

单例模式

type bike struct {
	ID int
}

var (
	once sync.Once
	singleton *bike
)

func GetSingleton() *bike {
	once.Do(func() {
		singleton = new(bike)
	})
	return singleton
}

func main() {
	b := GetSingleton()
	b.ID = 1
	b = GetSingleton()
	fmt.Println(b.ID)
}

对象池模式

type bike struct {
	ID int
}

type bikePool struct {
	pool sync.Pool
}

func NewBikePool() *bikePool {
	p := new(bikePool)
	p.pool = sync.Pool{
		New: func() interface{} {
			return new(bike)
		},
	}
	return p
}

func (p *bikePool) Get() *bike {
	return p.pool.Get().(*bike)
}

func (p *bikePool) Put(b *bike) {
	//may clear b
	//b.ID = 0
	p.pool.Put(b)
}

func main() {
	p := NewBikePool()
	b := p.Get()
	fmt.Println(b)
	p.Put(b)
}

结构型模式

适配器模式

  • 将一个类的接口转换成客户希望的另外一个接口。适配器模式使得原本由于接口不兼容而不能一起工作的那些类可以一起工作
type run interface {
	run(string)
}

type adapter struct {
	r1 run
}

func (a *adapter) run(e int) {
	energy := ""
	switch e {
	case 1:
		energy = "oil"
	case 2:
		energy = "electricity"
	}
	a.r1.run(energy)
}

type car struct {}

func (c *car) run(energy string) {
	if energy != "oil" {
		fmt.Printf("car can't run with %s!\n",energy)
		return
	}
	fmt.Println("car is running")
}

func main() {
	c := &car{}
	a := adapter{
		r1: c,
	}
	a.run(1)
}

代理模式

package main

import (
	"fmt"
)

type car struct {
	color string
}

func (c *car) run() {
	fmt.Printf("%s car is running",c.color)
}

type CarProxy struct {
	c car
}

func (c *CarProxy) run() {
	c.c.run()
}

func NewCarProxy(color string) *CarProxy {
	return &CarProxy{
		car{color: color},
	}
}

func main() {
	p := NewCarProxy("red")
	p.run()
}

装饰器模式

  • 动态地给一个对象添加一些额外的职责。就增加功能来说,装饰器模式相比生成子类更为灵活
package main

//echo的middleware就是这种模式
type abs func(int)int

func decorator(o abs) abs {
	return func(a int) int {
		if a < 0 {
			a = -a
		}
		return o(a)
	}
}

func main() {
	f := func(a int) int {
		return a
	}
	fmt.Println(f(-1))
	f = decorator(f)
	fmt.Println(f(-1))
}

type vehicle interface {
	run()
}

type decorator struct {
	v vehicle
}

func (d *decorator) run() {
	fmt.Println("decorated")
	d.v.run()
}

type car struct {}

func (c *car) run() {
	fmt.Println("car is running")
}

func main() {
	c := &car{}
	d := &decorator{c}
	d.run()
}
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值