【发布时间】:2017-12-13 21:30:18
【问题描述】:
我有一整套如下所示的函数:
package rules;
import "project/some"
func frobDiscountLimit(frob some.Frob, maxDiscount float64) (RuleStatus, string)
func frobDiscountPercentageLimit(frob some.Frob, maxDiscountPercentage float64) (RuleStatus, string)
func frobUsageLimit(frob some.Frob, interval valueInterval) (RuleStatus, string)
func frobPermanentExpiryLimit(frob some.Frob) (RuleStatus, string)
func frobVoucherValidity(frob some.Frob, maxValidityDays uint) (RuleStatus, string)
使用示例:
package rules
import "project/some"
func doChecks(frob some.Frob) {
status, message := frobDiscountLimit(frob, 100)
if status != PASSED {
....
}
... evaluate all remaining rules here ...
}
我想知道这样写有什么好处:
func (f someFrob) discountLimit(maxDiscount float64) (RuleStatus, string)
...
写起来似乎更短,但我不确定哪种风格是正确的。因为我不认为这些验证方法是“对象的一部分”,所以它们不是some.Frob 对象行为的一部分(与some.Frob 的属性的getter 或setter 不同)。
【问题讨论】: