如何在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)
}