简单工厂模式

nodeadbird · · 123 次点击 · · 开始浏览    

1.1. 模式动机

考虑一个简单的软件应用场景,一个软件系统可以提供多个外观不同的按钮(如圆形按钮、矩形按钮、菱形按钮等), 这些按钮都源自同一个基类,不过在继承基类后不同的子类修改了部分属性从而使得它们可以呈现不同的外观,如果我们希望在使用这些按钮时,不需要知道这些具体按钮类的名字,只需要知道表示该按钮类的一个参数,并提供一个调用方便的方法,把该参数传入方法即可返回一个相应的按钮对象,此时,就可以使用简单工厂模式。

1.2. 模式定义

简单工厂模式(Simple Factory Pattern):又称为静态工厂方法(Static Factory Method)模式,它属于类创建型模式。在简单工厂模式中,可以根据参数的不同返回不同类的实例。简单工厂模式专门定义一个类来负责创建其他类的实例,被创建的实例通常都具有共同的父类。

1.3. 模式结构

简单工厂模式包含如下角色:

Factory:工厂角色

工厂角色负责实现创建所有实例的内部逻辑

Product:抽象产品角色

抽象产品角色是所创建的所有对象的父类,负责描述所有实例所共有的公共接口

ConcreteProduct:具体产品角色

具体产品角色是创建目标,所有创建的对象都充当这个角色的某个具体类的实例。

1.4. 代码分析

go 语言没有构造函数一说,所以一般会定义NewXXX函数来初始化相关类。 NewXXX 函数返回接口时就是简单工厂模式,也就是说Golang的一般推荐做法就是简单工厂。

在这个simplefactory包中只有API 接口和NewAPI函数为包外可见,封装了实现细节,如下:

package simplefactory

import "fmt"

//API is interface

type API interface {

  Say(name string) string

}

//NewAPI return Api instance by type

func NewAPI(t int) API {

  if t == 1 {

      return &hiAPI{}

  } else if t == 2 {

      return &helloAPI{}

  }

  return nil

}

//hiAPI is one of API implement

type hiAPI struct{}

//Say hi to name

func (*hiAPI) Say(name string) string {

  return fmt.Sprintf("Hi, %s", name)

}

//HelloAPI is another API implement

type helloAPI struct{}

//Say hello to name

func (*helloAPI) Say(name string) string {

  return fmt.Sprintf("Hello, %s", name)

}

package simplefactory

import "testing"

//TestType1 test get hiapi with factory

func TestType1(t *testing.T) {

  api := NewAPI(1)

  s := api.Say("Tom")

  if s != "Hi, Tom" {

      t.Fatal("Type1 test fail")

  }

}

func TestType2(t *testing.T) {

  api := NewAPI(2)

  s := api.Say("Tom")

  if s != "Hello, Tom" {

      t.Fatal("Type2 test fail")

  }

}


有疑问加站长微信联系(非本文作者)

本文来自:简书

感谢作者:nodeadbird

查看原文:简单工厂模式

入群交流(和以上内容无关):加入Go大咖交流群,或添加微信:liuxiaoyan-s 备注:入群;或加QQ群:1006366459

123 次点击  
加入收藏 微博
暂无回复
添加一条新回复 (您需要 登录 后才能回复 没有账号 ?)
  • 请尽量让自己的回复能够对别人有帮助
  • 支持 Markdown 格式, **粗体**、~~删除线~~、`单行代码`
  • 支持 @ 本站用户;支持表情(输入 : 提示),见 Emoji cheat sheet
  • 图片支持拖拽、截图粘贴等方式上传