3

我想把我所有的模型放在一个共享Common库中。

所以,我做了一个新的回购:gitlab.com/xxx/common

我在里面放了一个包:models

这是对象的定义:

type Meter struct {
    ID           string
    OperationID  string
    Type         ConsoProd
    Unit         string
    Timestep     time.Duration
    Measures     []Measure 
    FetchMethod  AcquisitionMethod
    Metadata     interface{}
}

现在,我想在外部项目中使用它,我这样做:

go get gitlab.com/xxx/common

Go Modules 会下载它。

我像这样导入使用它:

import "gitlab.com/xxx/common/models"

//String transparent method
func (meter models.Meter) String() string {
    var stringifyMeter string
    stringifyMeter += "Meter " + meter.ID + " is a " + meter.Type.String() + " and compute in operation #" + meter.OperationID + "."
    return stringifyMeter
}

但是Goland不会解决它,当我编译时,我得到:

cannot define new methods on non-local type models.Meter

为什么会发生,我能做些什么来解决它?

4

2 回答 2

4

不允许在定义类型的包之外定义方法。这为您提供了几个选择:

  1. 定义models包中的方法。这是处理您自己的代码时最简单的方法,但当然不适用于第 3 方类型。

  2. 创建一个常规函数而不是方法 ( func String(meter models.Meter) string)。不过,这可能不那么惯用(特别是对于String方法),并且也无法访问私有字段(除非您在models包中定义了函数,在这种情况下,您可以只定义方法)。

  3. 创建嵌入原始类型的新类型。这使用起来有点麻烦,但允许您扩展现有行为。像这样的东西:

`

package main

import (
    "fmt"
    "time"
)

func main() {
    myTime := MyTime{time.Now()}
    fmt.Println(myTime)        /* behaves as time.Time */ 
    fmt.Println(myTime.Foo())  /* also has extra methods */
}

type MyTime struct {
  time.Time
}

func (m MyTime) Foo() string {
  return "foo"
}
于 2019-07-19T10:22:00.830 回答
1

简单的,

import ...bla/bla/Meter

type extended Meter

参考:https ://github.com/golang/go/issues/31631#issuecomment-486075295

于 2021-01-05T15:39:29.887 回答