在Go 中建立不同的通道
在此程式設計問題中,Go 初學者尋求一種有效的方法來定義輸出唯一值的頻道。具體要求是建立一個接受整數值並且僅傳輸不同整數的通道。目標是避免輸出中出現重複的整數。
其中一個回應建議使用對應來儲存先前傳輸的值以實現此功能。雖然這種方法可以有效消除重複值,但記憶體使用是一個考慮因素。地圖資料結構需要分配和維護鍵值對的集合,如果管理不仔細,可能會導致記憶體洩漏。
為了提供實用的解決方案,以下程式碼片段介紹了UniqueGen 函數,該函數產生指定範圍內唯一整數的通道:
<code class="go">func UniqueGen(min, max int) <-chan int { m := make(map[int]struct{}, max-min) ch := make(chan int) go func() { for i := 0; i < 1000; i++ { v := min + rand.Intn(max) if _, ok := m[v]; !ok { ch <- v m[v] = struct{}{} } } close(ch) }() return ch }</code>
UniqueGen 函數使用映射來記錄傳輸的整數。它啟動一個 goroutine,重複產生指定範圍內的整數。對於每個產生的值,該函數透過在映射中尋找來檢查它是否已傳輸。如果沒有,它會透過通道發送整數並將其記錄在映射中。此過程有效地過濾掉重複值,確保僅透過通道傳輸不同的整數。
使用 UniqueGen 函數,可以實現以下測試案例來演示該行為:
<code class="go">func TestShouldReturnDistinctValues(t *testing.T) { var c = make([]chan int) c <- UniqueGen(1, 1000) for e := range c { // only print distinct values fmt.println(e) } }</code>
此測試用例將產生一個包含 1000 個唯一整數的通道並將它們列印到控制台。透過利用 UniqueGen 函數,測試可以確保其輸出不同的值。
以上是如何在 Go 中創建唯一整數的通道?的詳細內容。更多資訊請關注PHP中文網其他相關文章!