代码拉取完成,页面将自动刷新
OpenMix 出品:https://openmix.org
DI、IoC 容器
DI, IoC container
一个创建对象以及处理对象依赖关系的库,该库可以实现统一管理依赖,全局对象管理,动态配置刷新等。
go get github.com/mix-go/xdi
通过依赖配置实例化一个单例
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
}
依赖配置中引用另一个依赖配置的实例
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()
可以刷新单例的实例来切换使用新的配置,通常在微服务配置中心中使用。
obj, err := xdi.Container().Object("foo")
if err != nil {
panic(err)
}
if err := obj.Refresh(); err != nil {
panic(err)
}
Apache License Version 2.0, http://www.apache.org/licenses/
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。