douhong6187 2016-09-27 01:38
浏览 32
已采纳

Golang:对象的方法表达式实例

I'm trying to build a variadic function for a constructor in golang and I've ran into an interesting issue. This function is working...

package main
import "fmt"
type person struct {
    name string
}

// This is working, but a really Not how I want to do this
func personConstructor(params ...string) person {
    name := "Unnamed Person" // Default name
    if len(params) > 0 {
        name = params[0]
    }
    return person{name: name}
}

func main() {
    bob := personConstructor("Bob")
}

https://play.golang.org/p/dcAdHEQtYz

And yet this, isn't.

package main

import "fmt"

type person struct {
    name string
}

// This isn't working
func (p person) constructor(params ...string) person {
    name := "Unnamed Person" // Default name
    if len(params) > 0 {
        name = params[0]
    }
    return person{name: name}
}
func main() {
    bob := person.constructor("Bob")
}

https://play.golang.org/p/YiTQctu-1A

Any idea as to why this is?

  • 写回答

2条回答 默认 最新

  • doukongyong44772 2016-09-27 04:27
    关注

    The introduction in the Go tour provides a concise answer to your question.

    Go does not have classes. However, you can define methods on types.

    Your examples assume that the constructor function is defined on the definition of the person struct. This is not the case. A method operates on an instance of a type referred to as a receiver. A constructor is not possible in this mechanism. The established pattern within the Go community is to use a factory function to initialize a struct and is exemplified in your first function definition.

    The second example provided is failing because constructor is expecting to be called on an instance of a person which is undefined. If you construct a new instance of a person struct the function behaves as expected.

    // https://play.golang.org/p/5XDGSTMVj9
    
    func (p person) constructor(params ...string) person {
        name := "Unnamed Person" // Default name
        if len(params) > 0 {
            name = params[0]
        }
        return person{name: name}
    }
    
    func main() {
        // Lets define a new instance of a person struct
        p := person{}
    
        // The function, when called on a instance, works as expected
        bob := p.constructor("Bob")
    
        fmt.Printf("%+v
    ", bob)
    }
    

    This illustrates that methods are attributed to an instance of a particular type.

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?