Skip to content

Latest commit

 

History

History
113 lines (77 loc) · 2.09 KB

container.md

File metadata and controls

113 lines (77 loc) · 2.09 KB

简介

ContainerFirmeve的基础,一切都是以Container为基础实现ioc开始。

基础示例

新建容器

var c = container.New()

数据绑定

// 单例数据绑定
foo := new(Foo)
c.Bind("foo", foo)

// 绑定函数
var f = func() string {
  return "rand string"
}
c.Bind("f", f)

// 绑定slice
var s = []string{"a", "b"}
c.Bind("s", s)

// 强制覆盖已存在的单例
c.Bind("foo", new(Foo2), WithCover(true))

注意

  1. 绑定的类型仅支持:array, slice, map, func, prt(struct), struct
  2. 只有函数类型是非单例类型,每次调用时会自动执行函数方法来获取结果
  3. 更多高级用户请参见 container_test

数据获取

// 判断原有对象是否存在
if c.Has("Foo") {
	// 获取一个已存在的对象
  c.Get("Foo").(*Foo)
}

// 删除一个对象
c.Remove("Foo")

// 清除容器所有对象
c.Flush()

实例解析

通过Make方法可以轻松完成自动解析,目前解析对象包括:

  • 容器中已存在对象
  • 结构体
  • 函数
// 解析容器中已存在的对象,同Get()
c.Make("Foo")

// 解析结构体
type Person struct {
   Bar *Bar `inject:"bar"`
   Foo *Foo `inject:"foo"`
}
c.Make(new(Person))

// 解析函数

// 普通标量函数
func NormalSample(id int, str string) (int, string) {
   return id, str
}
fmt.Printf("%v", c.Make(NormalSample, 10, `foo`))

// 支持多级函数嵌套
// 假设 *Nesting *Sample 已存在于容器中
func StructFuncFunc(id int, nesting *Nesting, fn func(nesting *Nesting) int, prt *Sample) int {
   return id + fn(nesting) + prt.Id
}

// 容器会自动解析已存在的 *Nesting *Sample
// 对于手动定义的参数,必须放在函数前置
fmt.Printf("%v", c.Make(StructFuncFunc, 10))

注意:

  • 如果解析注入的对象不是指针类型则会自动忽略,不会自动赋值。
  • 带有动态参数...params的函数暂时无法解析

单独使用

go get -u github.com/firmeve/firmeve/container