多様なランタイムタイプ用の汎用コンテナーを使用する
問題ステートメント:
ジェネリックスを使用してあらゆるデータ型に対応できる Go チャネル。ゴルーチンがさまざまなデータを処理できるようにします。
解決策:
ジェネリックを使用する提案されたアプローチは正しくありません。ジェネリックは、使用前に特定の型でインスタンス化する必要があります。代わりに、任意の型を処理できるチャネルの場合、タイプ chan インターフェースのチャネルを作成する必要があります。{}特定の型を保持できるチャネルなどのパラメータ化された型。ただし、具体的な型を指定せずに任意の型を受け入れることができるチャネルを作成することはできません (チャネル T など)。
チャネルをデータの送受信に使用できるようにするには、その型を指定する必要があります。 。例:
この汎用チャネルを使用するには、具象型でインスタンス化する必要があります: ジェネリックを使用した間違ったアプローチ:type GenericChan[T any] chan T
質問で提供されているコードは、次のような任意の型を保持できる汎用チャネルを作成しようとしています。 as:
c := make(GenericChan[int])
ただし、チャネル タイプが未定義であるため、これは正しくありません。コードをコンパイルすると、次のようになります。
chan インターフェースを使用した正しいアプローチ{}:func StartController[T any](sender chan Packet[T]) { go runThread(sender) }
.\test.go:8:22: cannot use generic type Packet[T interface{}] without instantiation
このチャネルはあらゆるタイプのデータを受け入れることができ、さまざまな goroutine と互換性があります。このチャネルからデータを受信するとき、受信側は型アサーションを使用して実際のデータ型を決定する必要があります:
ジェネリックと型パラメーターを使用した代替方法:sender := make(chan interface{})
data := <-sender fmt.Println(data.(int)) // Type assertion to retrieve the int value
この関数は、型安全性を維持しながら、chan int または chan string を使用して呼び出すことができます。
以上がGo ジェネリックは多様なランタイム タイプのチャネルを作成できますか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。