當涉及透過通道將資料傳送到goroutine 進行進一步處理時,需要一個可以處理任何類型的通道類型經常出現。隨著 Go 1.18 中泛型的引入,這樣的挑戰似乎是可以應付的。然而,有一個問題:在初始化時為 goroutine 指定通道類型仍然是一個障礙,因為它可以保存任何資料類型。
為了解決這個問題,請考慮以下範例程式碼:
type Message[T any] struct { Data T } type Packet[T any] struct { Msg Message[T] } func StartController[T any](sender chan Packet[T]) { go runThread(sender) } func runThread[T any](sender chan Packet[T]) { for true { data := <-sender fmt.Println(data) } }
在這段程式碼中,StartController 函數啟動了一個執行 runThread 函數的 goroutine。但是,由於嘗試在沒有實例化的情況下使用泛型類型 Packet[T interface{}],因此會出現編譯錯誤。
一個常見的誤解是使用泛型來建立可以容納任何類型的通道。與 Java 的 List
舉個例子,考慮Java 的泛型收集器ArrayList
c := make(chan interface{})
在這種情況下,通道可以接受任何類型的數據。然而,問題出現了:通用通道應該如何處理接收操作?如果可以向其中發送任何內容,那麼接收到的項目的資料類型是什麼?
因此,最合適的解決方案仍然是 chan interface{},並在接收到專案時進行類型斷言,就像程式碼中沒有實現的那樣泛型。
相反,泛型的真正價值在於編寫處理任意類型的程式碼,同時保持型別安全。例如:
func receiveAny[T any](c chan T) T { return <-c }
可以使用 chan int 或 chan 字串呼叫此函數。
以上是如何使用 Go 泛型建立處理不同運行時類型的類型安全通道?的詳細內容。更多資訊請關注PHP中文網其他相關文章!