亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

在函數參數中傳遞接口指針

在函數參數中傳遞接口指針

Go
隔江千里 2023-07-26 20:01:18
我試圖理解 Golang (1.12) 接口。我發現接口指針必須顯式取消引用,與結構不同:import "fmt"// A simple interface with one functiontype myinter interface {    hello()}// Implement myintertype mystruct struct {}func (mystruct) hello() {    fmt.Println("I am T!")}// Some function that calls the hello function as defined by myinterfunc callHello(i *myinter) {       i.hello()  // <- cannot resolve reference 'hello'}func main() {    newMystruct := &mystruct{}    callHello(newMystruct)}在這里,我的函數無法解析接口中定義的callHello對我的函數的引用。hello當然,取消引用接口是可行的:func callHello(i *myinter) {       (*i).hello()  // <- works!}但在結構體中,我們可以直接調用函數,不需要這種繁瑣的解引用符號:func callHello(s *mystruct) {       s.hello()  // <- also works!}為什么會這樣呢?我們必須顯式取消引用指針是否有原因interface?Go 是否試圖阻止我將interface指針傳遞給函數?
查看完整描述

3 回答

?
慕尼黑5688855

TA貢獻1848條經驗 獲得超2個贊

Go 是否試圖阻止我將接口指針傳遞給函數?

是的。

在(幾乎*)所有情況下,接口指針都是錯誤的。

(* 在非常罕見和微妙的情況下,指針到接口是有意義的,但很有可能您每 5 年不會看到它們超過一次。)

(挑剔:該語言稱為“Go”?!癵olang.org”是網站。類似的基礎知識包含在兼容性承諾中,并且不依賴于版本:Go 1.0、1.12 和 1.16 在這方面的行為完全相同.)


查看完整回答
反對 回復 2023-07-26
?
www說

TA貢獻1775條經驗 獲得超8個贊

它與類型系統的工作方式有關。接口類型I定義了方法集。方法集是為 type 定義的I,而不是為 type 定義的*I。正因為如此,其使用*I受到限制。當函數要設置接口值時可以使用它,但很少見:


func f(x *error) {

  *x = fmt.Errorf("Some error")

}

請注意,接口本身可以有一個底層指針值:


func f(x someInterface) {

   *x.(*someType) = value

}


func main() {

   x := someType{}

   f(&x)

}

這對于非接口類型是不同的。當您為非接口類型 定義方法時,該方法同時為和T定義。如果您為 定義方法,則它僅是為 定義的,而不是為 定義的。T*T*T*TT


查看完整回答
反對 回復 2023-07-26
?
料青山看我應如是

TA貢獻1772條經驗 獲得超8個贊

只需移除指針即可使用該界面。


func callHello(i myinter) {   

    i.hello()  

}

該 func 現在將接受實現該接口的結構實例,或指向實現該接口的結構實例的指針。


func main() {

    instance := mystruct{}

    pointer := &mystruct{}

    callHello(instance)

    callHello(pointer)

}

輸出以下內容:


I am T!

I am T!

 

Program exited.


查看完整回答
反對 回復 2023-07-26
  • 3 回答
  • 0 關注
  • 184 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號