Go语言之函数方法(2)

有没有发现,在上面的例子中,我们在调用指针接收者方法的时候,使用的也是一个值的变量,并不是一个指针。如果我们使用下面的方法也是可以的。

 

p:=person{name:"张三"} (&p).modify() //指针接收者,修改有效

 

如果我们没有这么强制使用指针进行调用,Go的编译器自动帮我们取指针,以满足接收者的要求。

 

同样的,如果是一个值接收者的方法,使用指针也是可以调用的。Go编译器自动解引用,以满足接收者的要求。比如例子中定义的String()方法,也可以这么调用:

 

p:=person{name:"张三"} fmt.Println((&p).String())

 

总之,方法的调用,既可以使用值,也可以使用指针。我们不必要严格的遵守这些,Go语言编译器会帮我们进行自动转义的,这大大方便了我们开发者。

 

不管是使用值接收者,还是指针接收者,一定要搞清楚类型的本质:对类型进行操作的时候,是要改变当前值,还是要创建一个新值进行返回?这些就可以决定我们是采用值传递,还是指针传递。

多值返回

Go语言支持函数方法的多值返回,也就说我们定义的函数方法可以返回多个值。比如标准库里的很多方法,都是返回两个值:第一个是函数需要返回的值,第二个是出错时返回的错误信息。这样的好处是,我们的出错异常信息再也不用像Java一样,需要使用Exception这么重的方式表示了,非常简洁。

 

func main() {     file, err := os.Open("/usr/tmp")     if err != nil {         log.Fatal(err)         return     }     fmt.Println(file) }

 

返回的值如果我们不想使用,可以使用_进行忽略。

file, _ := os.Open("/usr/tmp")

 

多个值返回的定义也非常简单,看个例子。

 

func add(a, b int) (int, error) {     return a + b, nil }

函数方法声明定义的时候,采用逗号分割,因为是多个返回,还要用括号括起来。返回的值还是使用return关键字,以逗号分割,和返回声明的顺序一致。

可变参数

函数方法的参数,可以是任意多个,这种我们称之为可以变参数。比如我们常用的fmt.Println()这类函数,可以接收一个可变的参数。

func main() {     fmt.Println("1","2","3") }

 

可以变参数,可以是任意多个。我们自己也可以定义可以变参数,可变参数的定义,在类型前加上省略号...即可。

 

func main() {     print("1","2","3") } func print (a ...interface{}){     for _,v:=range a{         fmt.Print(v)     }     fmt.Println() }

 

例子中我们自己定义了一个接受可变参数的函数,效果和fmt.Println()一样。

 

可变参数本质上是一个数组,所以我们像使用数组一样使用它,比如例子中的 for range循环。

内容版权声明:除非注明,否则皆为本站原创文章。

转载注明出处:https://www.heiqu.com/14d3797ef89ee35260a1379dba2578ee.html