您好,登錄后才能下訂單哦!
這篇文章給大家分享的是有關(guān)golang中方法的receiver為指針和不為指針的有哪些區(qū)別的內(nèi)容。小編覺得挺實(shí)用的,因此分享給大家做個(gè)參考,一起跟隨小編過來看看吧。
golang 是Google開發(fā)的一種靜態(tài)強(qiáng)類型、編譯型、并發(fā)型,并具有垃圾回收功能的編程語(yǔ)言,其語(yǔ)法與 C語(yǔ)言相近,但并不包括如枚舉、異常處理、繼承、泛型、斷言、虛函數(shù)等功能。
golang中方法的receiver為指針和不為指針的區(qū)別
其實(shí)只要明白這個(gè)原理,基本就能理解上面提到的問題.
方法其實(shí)就是一種特殊的函數(shù),receiver就是隱式傳入的第一實(shí)參.
舉個(gè)例子
type test struct{ name string } func (t test) TestValue() { } func (t *test) TestPointer() { } func main(){ t := test{} m := test.TestValue m(t) m1 := (*test).TestPointer m1(&t) }
是不是很簡(jiǎn)單就明白了呢?現(xiàn)在我們來加入代碼,來看看指針和非指針有什么區(qū)別.
type test struct{ name string } func (t test) TestValue() { fmt.Printf("%p\n", &t) } func (t *test) TestPointer() { fmt.Printf("%p\n", t) } func main(){ t := test{} //0xc42000e2c0 fmt.Printf("%p\n", &t) //0xc42000e2e0 m := test.TestValue m(t) //0xc42000e2c0 m1 := (*test).TestPointer m1(&t) }
估計(jì)有的同學(xué)已經(jīng)明白了,當(dāng)不是指針時(shí)傳入實(shí)參后值發(fā)生了復(fù)制.所以每調(diào)用一次TestValue()值就發(fā)生一次復(fù)制.
那如果涉及到修改值的操作,結(jié)果會(huì)是怎樣呢?
type test struct{ name string } func (t test) TestValue() { fmt.Printf("%s\n",t.name) } func (t *test) TestPointer() { fmt.Printf("%s\n",t.name) } func main(){ t := test{"wang"} //這里發(fā)生了復(fù)制,不受后面修改的影響 m := t.TestValue t.name = "Li" m1 := (*test).TestPointer //Li m1(&t) //wang m() }
所以各位同學(xué)在編程遇到此類問題一定要注意了.
那這些方法集之間到底是什么關(guān)系呢?這里借用了qyuhen在golang讀書筆記的話,這里也推薦喜歡golang的朋友去閱讀這本書,對(duì)加深理解golang有很大的幫助.
? 類型 T 法集包含全部 receiver T 法。
? 類型 T 法集包含全部 receiver T + T 法。
? 如類型 S 包含匿名字段 T,則 S 法集包含 T 法。
? 如類型 S 包含匿名字段 T,則 S 法集包含 T + T 法。
? 不管嵌 T 或 T,S 法集總是包含 T + *T 法。
感謝各位的閱讀!關(guān)于“golang中方法的receiver為指針和不為指針的有哪些區(qū)別”這篇文章就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,讓大家可以學(xué)到更多知識(shí),如果覺得文章不錯(cuò),可以把它分享出去讓更多的人看到吧!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。