方法method
- Go 中虽没有class,但依旧有method
- 通过显示说明receiver来实现与某个类型的组合
- 只能为同一个包中的类型定义方法
- Receiver 可以是类型的值或者指针
- 不存在方法重载
- 可以使用值或指针来调用方法,编译器会自动完成转换
- 从某种意义上来说,方法是函数的语法糖,因为receiver其实就是
- 方法所接收的第1个参数(Method Value vs. Method Expression)
- 如果外部结构和嵌入结构存在同名方法,则优先调用外部结构的方法
- 类型别名不会拥有底层类型所附带的方法
- 方法可以调用结构中的非公开字段
package main
import (
"fmt"
)
type A struct {
Name string
}
type B struct {
Name string
}
func main() {
//Receiver 可以是类型的值或者指针
a := A{}
a.Print()
fmt.Println(a.Name) //打印为修改后的值
b := B{}
b.Print()
fmt.Println(b.Name) //打印为空
}
//引用类型,指针的拷贝
func (a *A) Print() {
a.Name = "AA"
fmt.Println("A...")
}
//值类型,值得拷贝
func (b B) Print() {
b.Name = "BB"
fmt.Println("B...")
}
package main
import (
"fmt"
)
type TTT int
func main() {
//类型别名不会拥有底层类型所附带的方法
var a TTT
fmt.Println(a)
a.Print() //Method Value
(*TTT).Print(&a) //Method Expression
}
func (a *TTT) Print() {
fmt.Println("TTT",a)
}
package main
import (
"fmt"
)
type A struct {
name string //同一个包来讲,私有的也是可见的
}
func main() {
//方法可以调用结构中的非公开字段
a := A{}
a.Print()
fmt.Println(a.name)
}
func (a *A) Print() {
a.name = "123"
fmt.Println(a)
}
package main
import (
"fmt"
)
type A int
func (a *A) Increase(num int) {
*a += A(num)
}
func main() {
//声明一个底层类型为int的类型,并实现调用某个方法就递增100
var a A
a.Increase(100)
fmt.Println(a)
}
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。