首頁 >後端開發 >Golang >為什麼 Go 中的指標接收器的連結方法呼叫失敗?

為什麼 Go 中的指標接收器的連結方法呼叫失敗?

Susan Sarandon
Susan Sarandon原創
2024-11-29 13:03:10561瀏覽

Why Does Chaining Method Calls Fail with Pointer Receivers in Go?

理解Go 中的「無法取得位址」和「無法呼叫指標方法」

儘管功能相似程式碼片段中,一個可以編譯並且運行,而另一個會產生錯誤:

// This compiles and works
diff := projected.Minus(c.Origin)
dir := diff.Normalize()

// This does not (yields the errors in the title)
dir := projected.Minus(c.Origin).Normalize()

差異歸因於Normalize()方法的接收器類型的差異。

Go 方法中的接收器類型

Go 方法可以有值接收器或指標接收者。值接收器對結構的副本進行操作,而指標接收器則對原始結構本身進行操作。

在 Normalize() 的情況下,它有一個指標接收器,需要一個指向 Vector3 值的指標作為接收者。

尋址變數和回傳值

Go 中的變數是可尋址的,這表示變數的位址可以作為參數傳遞給指標接收器方法。但是,函數和方法呼叫的回傳值是不可尋址的。

帶有指標接收器的鍊式呼叫

在編譯的範例中,編譯器會自動取得位址diff 變數以符合 Normalize() 的指標接收器。

在未編譯的範例中,編譯器無法自動取得Minus() 回傳值的位址,因為它無法定址。傳回值是副本,必須先將其指派給變量,以便取得其位址。

解決方法

存在多種解決方法來解決該問題:

  • 值接收者:修改Normalize() 為值接收器,無需取得傳回值的位址。
  • 指標傳回值:修改 Minus() 以傳回指向 Vector3 的指標。
  • 輔助函數: 建立一個傳回值位址的輔助函數,允許所需的連結

接收器和結果類型的一致性

建議在整個自訂類型中保持接收器和結果類型的一致性。如果大多數方法都有指標接收器,則所有方法都應該使用指標接收器。同樣,如果大多數方法都返回指針,那麼所有方法都應該返回指針。

以上是為什麼 Go 中的指標接收器的連結方法呼叫失敗?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn