首頁 資訊 財經 公益 彩店 奇聞 速遞 體育 提點 資訊 綜合 企業 市場

          首頁
          你現在的位置:

          消息!go的數據類型-其他數據類型-channel(二)

          2023-04-21 16:04:35    來源:騰訊云    作者:


          【資料圖】

          Channel的使用示例

          以下是一個使用Channel的示例程序,該程序創建了兩個Goroutine,并使用Channel在它們之間進行通信和同步。

          package mainimport ("fmt""time")func worker(id int, jobs <-chan int, results chan<- int) {for j := range jobs {fmt.Printf("worker %d started job %d\n", id, j)time.Sleep(time.Second)fmt.Printf("worker %d finished job %d\n", id, j)results <- j * 2}}func main() {jobs := make(chan int, 100)results := make(chan int, 100)for w := 1; w <= 3; w++ {go worker(w, jobs, results)}for j := 1; j <= 9; j++ {jobs <- j}close(jobs)for a := 1; a <= 9; a++ {<-results}}

          在這個示例程序中,我們定義了一個名為worker的函數,它模擬了一個工作任務。這個函數接收一個jobs的單向Channel用于接收工作任務,以及一個results的單向Channel用于發送工作結果。當函數接收到一個工作任務時,它會等待一秒鐘,然后將工作結果發送到results的Channel中。

          main函數中,我們創建了兩個Channel:一個jobs的Channel用于發送工作任務,一個results的Channel用于接收工作結果。然后,我們啟動了三個Goroutine,并將它們分別分配給worker函數。接下來,我們向jobs的Channel中發送了9個工作任務,并關閉了這個Channel。最后,我們從results的Channel中接收了9個工作結果。

          在這個示例程序中,我們使用Channel實現了工作任務的分配和工作結果的收集。通過使用Channel,我們可以輕松地實現Goroutine之間的通信和同步,從而使程序變得簡單和高效。

          編輯:qysb005

          標簽:

          中國企業新聞網版權與免責聲明:
          1、中國企業新聞網所有內容的版權均屬于作者或頁面內聲明的版權人。未經中國企業新聞網的書面許可, 任何其他個人或組織均不得以任何形式將河南企業網的各項資源轉載、復制、編輯或發布使用于其他任何場合;不得把其中任何形式的資訊散發給其他方, 不可把這些信息在其他的服務器或文檔中作鏡像復制或保存;不得修改或再使用中國企業新聞網的任何資源。若有意轉載本站信息資料, 必需取得中國企業新聞網書面授權。否則將追究其法律責任。
          2、已經本網授權使用作品的,應在授權范圍內使用,并注明“來源:中國企業新聞網”。違反上述聲明者,本網將追究其相關法律責任。
          3、凡本網注明“來源:XXX(非中國企業新聞網)”的作品,均轉載自其它媒體,轉載目的在于傳遞更多信息, 并不代表本網贊同其觀點和對其真實性負責。本網轉載其他媒體之稿件,意在為公眾提供免費服務。如稿件版權單位或個人不想在本網發布, 可與本網聯系,本網視情況可立即將其撤除。
          圖片欣賞
          頻道推薦
          內容推薦
          最近更新