Golang对方法接收者变量的自动“取引用”和“解引用”
|
原文:?https://blog.csdn.net/u014633283/article/details/83826413 ------------------------------------------------------ 1. 写在前面 package main
import "fmt"
type StructTest struct{
data string
}
func (st StructTest) printData() {
fmt.Println(st.data)
}
type StructTest2 struct {
data string
}
func (st *StructTest2) printData(){
fmt.Println(st.data)
}
func main() {
st1 := StructTest{data: "seafooler"}
st1.printData()
st2 := &(StructTest{data: "seafooler"})
st2.printData()
st3 := StructTest2{data: "seafooler"}
st3.printData()
st4 := &(StructTest{data: "seafooler"})
st4.printData()
}
---------------------
作者:落日沧海
来源:CSDN
原文:https://blog.csdn.net/u014633283/article/details/83826413
版权声明:本文为博主原创文章,转载请附上博文链接!
? 2. 自动“取引用”或“解引用”遇到“接口” package main
import "fmt"
type InterfaceTest interface {
printData()
}
type StructTest struct {
data string
}
func (st StructTest) printData() {
fmt.Println(st.data)
}
type StructTest2 struct {
data string
}
func (st *StructTest2) printData() {
fmt.Println(st.data)
}
func main(){
st := StructTest{data: "seafooler"}
var it1 InterfaceTest = st
it1.printData()
var it2 InterfaceTest = &st
it2.printData()
st2 := StructTest2{data: "seafooler"}
var it3 InterfaceTest = st2 // 编译出错
it3.printData()
var it4 InterfaceTest = &st2
it4.printData()
}
---------------------
作者:落日沧海
来源:CSDN
原文:https://blog.csdn.net/u014633283/article/details/83826413
版权声明:本文为博主原创文章,转载请附上博文链接!
? 2.2 原因 StructTest值类型的printData方法会自动生成一个func (st *StructTest) printData()方法,因此*StructTest也是符合InterfaceTest接口的。相反,StructTest2指针类型的printData方法不会自动生成一个func (st StructTest2) printData()方法,因此StructTest2不符合InterFaceTest接口,也就不能将st2赋值给it33. 总结我们在谈到变量的自动“取引用”和“解引用”时,往往是指在进行“方法调用”的时候。而第2部分的示例代码中,涉及到类型的匹配,那就是另外一个问题了,涉及到的是新的相应方法的生成。值类型的方法总会生成一个对应的指针类型方法,反之则不可以--------------------- 作者:落日沧海 来源:CSDN 原文:https://blog.csdn.net/u014633283/article/details/83826413 版权声明:本文为博主原创文章,转载请附上博文链接! (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
