=` 或`" />
Go 結構比較:可比較且有序之間的誤解
在Go 中,如果結構的所有欄位都可比較,則預設將結構視為可比較。這意味著可以將一個結構體分配給相同類型的變量,或使用相等運算符(== 或 !=)與另一個相同類型的結構體進行比較。
但是,當嘗試在結構上使用有序運算符,例如 >= 或
在提供的範例中:
package main type Student struct { Name string // "String values are comparable and ordered, lexically byte-wise." Score uint8 // "Integer values are comparable and ordered, in the usual way." } func main() { alice := Student{"Alice", 98} carol := Student{"Carol", 72} if alice >= carol { println("Alice >= Carol") } else { println("Alice < Carol") } }
程式碼無法編譯,因為 >= 是有序運算子。編譯器偵測到 Student 未明確定義為有序類型,這是它支援有序比較所必需的。可以使用 == 或 != 來比較結構體值是否相等,但它們的順序關係(即 、=)未定義。
Go 語言規範明確指出:
「排序運算子 和>= 適用於已排序的運算元。[...] 如果所有欄位都可比較,則結構體值可比較。 = 這樣的有序運算符,除非它們被明確地宣告為有序類型。要啟用有序比較,自訂類型必須實作 sort.Interface 接口,這需要定義用於排序和比較類型實例的特定方法。
以上是為什麼我不能將 Go 結構體與 `>=` 或 ` 比較的詳細內容。更多資訊請關注PHP中文網其他相關文章!