如何在Go中保留工厂功能?
我试图保存一个函数,该函数将返回在结构中实现特定接口的类型的新实例。下面是一个简单的例子:如何在Go中保留工厂功能?,go,Go,我试图保存一个函数,该函数将返回在结构中实现特定接口的类型的新实例。下面是一个简单的例子: package main type Adder interface { Add(Adder) Val() int } type NewAdder func() Adder type number int type NewHolder struct { newFunc NewAdder } func (me *number)Add(it Adder) { *me +
package main
type Adder interface {
Add(Adder)
Val() int
}
type NewAdder func() Adder
type number int
type NewHolder struct {
newFunc NewAdder
}
func (me *number)Add(it Adder) {
*me += number(it.Val())
}
func (me *number)Val() int {
return int(*me)
}
func newAdder() *number {
return (*number)(new(int))
}
func main() {
var holder NewHolder
holder.newFunc = NewAdder(newAdder)
}
当我试图编译它时,它说无法将newAdder(type func()*number)转换为type newAdder
。那么,实现我的目标的方式是什么呢
下面是一个Python示例,说明我正在尝试做的事情,仅供参考:
class NewStuffMaker(object):
def __init__(self, new):
self.new = new
def make_new():
return []
obj = NewStuffMaker(make_new)
new_lst = obj.new()
理想情况下,我希望能够将这些函数(或包含函数和一些其他数据的结构)保存在一个切片中。这是不合理的做法吗?对于未来的人来说,如果其他人有这个问题,关键是函数声明为返回接口,而不是实现接口的类型。
package main
type Adder interface {
Add(Adder)
Val() int
}
type FuncAdder func() Adder
type Holder struct {
FuncAdder
SomeOtherData string
}
type number int
func (n *number) Add(a Adder) {
*n += number(a.Val())
}
func (n *number) Val() int {
return int(*n)
}
func NumberAdder() Adder {
return Adder(new(number))
}
func main() {
var holders []Holder
var holder Holder
holder.FuncAdder = NumberAdder
holder.SomeOtherData = "SomeOtherData"
holders = append(holders, holder)
}