小編給大家分享一下golang中方法的receiver為指針和不為指針有什么區(qū)別,希望大家閱讀完這篇文章之后都有所收獲,下面讓我們一起去探討吧!
公司主營業(yè)務(wù):網(wǎng)站建設(shè)、做網(wǎng)站、移動網(wǎng)站開發(fā)等業(yè)務(wù)。幫助企業(yè)客戶真正實現(xiàn)互聯(lián)網(wǎng)宣傳,提高企業(yè)的競爭能力。創(chuàng)新互聯(lián)公司是一支青春激揚、勤奮敬業(yè)、活力青春激揚、勤奮敬業(yè)、活力澎湃、和諧高效的團隊。公司秉承以“開放、自由、嚴(yán)謹(jǐn)、自律”為核心的企業(yè)文化,感謝他們對我們的高要求,感謝他們從不同領(lǐng)域給我們帶來的挑戰(zhàn),讓我們激情的團隊有機會用頭腦與智慧不斷的給客戶帶來驚喜。創(chuàng)新互聯(lián)公司推出佛山免費做網(wǎng)站回饋大家。
golang中方法的receiver為指針和不為指針的區(qū)別
最近看網(wǎng)站有同學(xué)提問golang中方法的receiver為指針和不為指針有什么區(qū)別,在這里我以簡單易懂的方法進行說明,幫助剛剛學(xué)習(xí)golang的同學(xué).
其實只要明白這個原理,基本就能理解上面提到的問題.
方法其實就是一種特殊的函數(shù),receiver就是隱式傳入的第一實參.
舉個例子
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) }
是不是很簡單就明白了呢?現(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) }
估計有的同學(xué)已經(jīng)明白了,當(dāng)不是指針時傳入實參后值發(fā)生了復(fù)制.所以每調(diào)用一次TestValue()值就發(fā)生一次復(fù)制.
那如果涉及到修改值的操作,結(jié)果會是怎樣呢?
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的朋友去閱讀這本書,對加深理解golang有很大的幫助.
? 類型 T 法集包含全部 receiver T 法。
? 類型 T 法集包含全部 receiver T + T 法。
? 如類型 S 包含匿名字段 T,則 S 法集包含 T 法。
? 如類型 S 包含匿名字段 T,則 S 法集包含 T + T 法。
? 不管嵌 T 或 T,S 法集總是包含 T + *T 法。
看完了這篇文章,相信你對“golang中方法的receiver為指針和不為指針有什么區(qū)別”有了一定的了解,如果想了解更多相關(guān)知識,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,感謝各位的閱讀!