从现在开始,我们要努力学习啦!今天我给大家带来《如何编写具有不同签名的同一方法的多个实现》,感兴趣的朋友请继续看下去吧!下文中的内容我们主要会涉及到等等知识点,如果在阅读本文过程中有遇到不清楚的地方,欢迎留言呀!我们一起讨论,一起学习!
问题内容我有几个相同方法 setrateformeasure
的实现:
package repartition
type repartition interface {
name() string
compute(meters []models.meter, totalsprod, totalsconso map[string]float64) []models.meter
setrateformeasure(meter models.meter, measure models.measure, total float64) float64
}
然后,在我的代码中(在 repartition.go 中),我将其称为:
rate := repartition.setrateformeasure(meter, measure, total)
其中repartition是之前定义的接口。
事实是,当我添加此方法的新实现时,我的函数的参数可能会有所不同。
例如,静态重新分区使用仅在本例中使用的静态百分比。
我最终添加了参数,以便对所有方法都有一个通用接口,但结果是根据实现的不同,有很多未使用的参数。
如果我将它添加到公共接口,它将不会用于其他定义。
我尝试从接口定义中删除此方法,但现在
rate := repartition.SetRateForMeasure()
不再定义。
我应该如何组织我的代码?
正确答案
go 中没有函数重载,因此不能使用不同的参数声明相同的函数。不过,您可以通过几种方法来实现这一点:
- 您可以添加具有不同名称和签名的多个函数
- 您可以更改函数以接受结构而不是参数
setrateformeasure(args setrateoptions) float64
type setrateoptions struct {
meter models.meter
measure models.measure
total float64
percentage *float64 // if nil, use default percentage
... // more parameters as needed
}
go 不支持方法重写。您可以定义具有不同名称并采用不同参数的方法 或者您可以声明接受参数结构的方法。
type SetRateParams struct {
Meter models.Meter
Measure models.Measure
Total float64
}
type Repartition interface {
SetRateForMeasure(params SetRateParams) float64
}
(可选)您可以将结构中的参数声明为指针,这样您就可以使用 nil
来表示“未提供”语义,而不是使用零值。这可能与 0
可能是有效值的数字参数有关。
使用结构体参数还有一个优点,即如果您决定从现在起 6 个月后添加额外的参数(只需将其添加到结构体中),则无需更改所有调用站点。
为了说明可能的情况,还有使用 interface{}
可变参数的更糟糕的解决方案,但除非您讨厌类型安全,否则我不建议这样做。
以上就是《如何编写具有不同签名的同一方法的多个实现》的详细内容,更多关于的资料请关注编程网公众号!