解Go 中的陣列/切片協方差限制:一種巧妙的方法
Go 缺乏陣列/切片協方差可能在處理異質時帶來挑戰收藏。考慮以下情況:
func printItems(header string, items []interface{}, fmtString string) { // ... } func main() { var iarr = []int{1, 2, 3} var farr = []float{1.0, 2.0, 3.0} printItems("Integer array:", iarr, "") printItems("Float array:", farr, "") }
不幸的是,由於Go 嚴格的類型系統,此程式碼將失敗並出現編譯錯誤:
prog.go:26: cannot use iarr (type []int) as type []interface { } in function argument prog.go:27: cannot use farr (type []float) as type []interface { } in function argument
複雜的解決方案:擁抱介面
克服此限制的一個優雅方法是利用Go 強大的介面系統。透過定義一個封裝類別數組集合基本屬性的接口,我們可以創建一個通用的解決方案:
type List interface { At(i int) interface{} Len() int } func printItems(header string, items List) { for i := 0; i < items.Len(); i++ { fmt.Print(items.At(i), " ") } fmt.Println() }
特定於類型的實現
對於每個具體類型,我們實作List介面:
type IntList []int type FloatList []float64 func (il IntList) At(i int) interface{} { return il[i] } func (fl FloatList) At(i int) interface{} { return fl[i] } func (il IntList) Len() int { return len(il) } func (fl FloatList) Len() int { return len(fl) }
範例用法
要使用我們的通用程式碼,我們將具體陣列包裝在自訂類型中:
func main() { var iarr = []int{1, 2, 3} var farr = []float64{1.0, 2.0, 3.0} printItems("Integer array:", IntList(iarr)) printItems("Float array:", FloatList(farr)) }
這種方法使我們能夠以通用方式操作異構集合,優雅地繞過Go缺乏陣列/切片協變性,同時遵守其慣用的類型安全原則。
以上是我們如何有效地處理 Go 的陣列/切片協方差限制?的詳細內容。更多資訊請關注PHP中文網其他相關文章!