内容简介: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 依赖注入容器》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!
猜你喜欢:本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。