内容简介:OpenMix 出品:https://openmix.org Mix XDI DI、IoC 容器 DI, IoC container Overview 一个创建对象以及处理对象依赖关系的库,该库可以实现统一管理依赖,全局对象管理,动态配置刷新等。 Installation go ge...
Mix XDI
DI、IoC 容器
DI, IoC container
Overview
一个创建对象以及处理对象依赖关系的库,该库可以实现统一管理依赖,全局对象管理,动态配置刷新等。
Installation
go get github.com/mix-go/xdi
Quick start
通过依赖配置实例化一个单例
package main import ( "github.com/mix-go/xdi" ) type Foo struct { } func init() { obj := &xdi.Object{ Name: "foo", New: func() (interface{}, error) { i := &Foo{} return i, nil }, } if err := xdi.Provide(obj); err != nil { panic(err) } } func main() { var foo *Foo if err := xdi.Populate("foo", &foo); err != nil { panic(err) } // use foo }
Reference
依赖配置中引用另一个依赖配置的实例
package main import ( "github.com/mix-go/xdi" ) type Foo struct { Bar *Bar } type Bar struct { } func init() { objs := []*xdi.Object{ { Name: "foo", New: func() (interface{}, error) { // reference bar var bar *Bar if err := xdi.Populate("bar", &bar); err != nil { return nil, err } i := &Foo{ Bar: bar, } return i, nil }, }, { Name: "bar", New: func() (interface{}, error) { i := &Bar{} return i, nil }, NewEverytime: true, }, } if err := xdi.Provide(objs...); err != nil { panic(err) } } func main() { var foo *Foo if err := xdi.Populate("foo", &foo); err != nil { panic(err) } // use foo }
Refresh singleton
程序执行中配置信息发生变化时,可以刷新单例的实例
obj, err := xdi.Container().Object("foo") if err != nil { panic(err) } if err := obj.Refresh(); err != nil { panic(err) }
License
以上所述就是小编给大家介绍的《Mix XDI V1.1 - Golang DI、IoC 依赖注入容器》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!
猜你喜欢:本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。