AVt天堂网 手机版,亚洲va久久久噜噜噜久久4399,天天综合亚洲色在线精品,亚洲一级Av无码毛片久久精品

當前位置:首頁 > 科技  > 軟件

Golang不可不知的七個并發(fā)概念

來源: 責編: 時間:2023-11-13 17:17:56 308觀看
導讀并發(fā)是Go編程語言的基本特性,意味著程序可以同時執(zhí)行多個任務。Golang的并發(fā)獨特而強大,其內置的輕量級協(xié)程(goroutine)和通道(channel)支持創(chuàng)建可伸縮、安全、高性能的高并發(fā)系統(tǒng)。本文將探索Go中和并發(fā)性有關的七個有

并發(fā)是Go編程語言的基本特性,意味著程序可以同時執(zhí)行多個任務。Golang的并發(fā)獨特而強大,其內置的輕量級協(xié)程(goroutine)和通道(channel)支持創(chuàng)建可伸縮、安全、高性能的高并發(fā)系統(tǒng)。btW28資訊網(wǎng)——每日最新資訊28at.com

btW28資訊網(wǎng)——每日最新資訊28at.com

本文將探索Go中和并發(fā)性有關的七個有趣事實,并提供示例。btW28資訊網(wǎng)——每日最新資訊28at.com

1. 協(xié)程(Goroutines)

Goroutine是Go編程語言的特性之一,這是輕量級線程,與同一地址空間中的其他goroutine并發(fā)運行。它的創(chuàng)建成本非常低,Go運行時可以同時處理數(shù)千個goroutine。Goroutine使編寫高并發(fā)程序變得容易,這些程序可以根據(jù)需要伸縮。btW28資訊網(wǎng)——每日最新資訊28at.com

下面是一個創(chuàng)建goroutine的例子:btW28資訊網(wǎng)——每日最新資訊28at.com

btW28資訊網(wǎng)——每日最新資訊28at.com

在本例中,定義了printMessage函數(shù),該函數(shù)接受一個消息字符串以及打印消息的次數(shù),其中sleep語句用來模擬在每次消息打印之間完成的一些額外工作。btW28資訊網(wǎng)——每日最新資訊28at.com

在main函數(shù)中,調用go printMessage("Hello", 5)和go printMessage("world", 5)來啟動兩個goroutine。這創(chuàng)建了兩個與主線程并發(fā)運行的獨立執(zhí)行線程。time.Sleep(1 * time.Second)語句用于將主線程暫停一秒鐘,這給了兩個goroutine足夠的時間來執(zhí)行和打印消息。btW28資訊網(wǎng)——每日最新資訊28at.com

2. 通道(Channels)

Channel是Go的另一個基本特性,支持在程序之間進行通信和同步。Channel是一種有類型管道,可以使用<-操作符發(fā)送和接收。Channel確保了并發(fā)進程之間安全有效的通信。btW28資訊網(wǎng)——每日最新資訊28at.com

下面是一個使用channel的例子:btW28資訊網(wǎng)——每日最新資訊28at.com

btW28資訊網(wǎng)——每日最新資訊28at.com

在本例中,make函數(shù)創(chuàng)建了一個string類型的channel。然后,我們創(chuàng)建一個使用<-操作符向channel發(fā)送消息"Hello from channel!"的goroutine。最后,我們使用<-操作符從channel接收消息并將其打印到控制臺。btW28資訊網(wǎng)——每日最新資訊28at.com

3. 緩沖通道(Buffered Channels)

緩沖通道是在讀取之前可以保存一定數(shù)量的值的通道,對于管理并發(fā)系統(tǒng)中的突發(fā)流量非常有用。使用make函數(shù)可以創(chuàng)建緩沖通道,通過第二個參數(shù)指定緩沖區(qū)大小。btW28資訊網(wǎng)——每日最新資訊28at.com

下面是一個使用緩沖通道的例子:btW28資訊網(wǎng)——每日最新資訊28at.com

btW28資訊網(wǎng)——每日最新資訊28at.com

在本例中,我們創(chuàng)建了一個緩沖區(qū)大小為2的int類型的緩沖通道。然后使用<-操作符向通道發(fā)送兩個值(1和2)。最后,我們使用<-操作符從通道接收值,并打印到控制臺。btW28資訊網(wǎng)——每日最新資訊28at.com

4. Select語句

Go中的select語句允許我們同時等待多個通道操作。這是個強大的結構,可以幫助我們編排復雜的并發(fā)系統(tǒng)。select語句會阻塞直到其中一個case可以繼續(xù)進行,此時就執(zhí)行該case。btW28資訊網(wǎng)——每日最新資訊28at.com

下面是一個使用select語句的例子:btW28資訊網(wǎng)——每日最新資訊28at.com

btW28資訊網(wǎng)——每日最新資訊28at.com

本例中創(chuàng)建了兩個通道(ch1和ch2)和兩個向這些通道發(fā)送消息的goroutine。然后,我們使用select語句等待消息到達ch1或ch2。當消息到達時,將其打印到控制臺。btW28資訊網(wǎng)——每日最新資訊28at.com

5. Mutex

Go中的互斥鎖(sync.Mutex)提供了一種簡單有效的方法來保護共享資源免受并發(fā)訪問。mutex是一種互斥鎖,一次只允許一個程序訪問資源,任何其他試圖在資源被鎖定時訪問該資源的goroutine都將被阻塞,直到鎖被釋放。btW28資訊網(wǎng)——每日最新資訊28at.com

下面是一個使用互斥鎖的例子:btW28資訊網(wǎng)——每日最新資訊28at.com

btW28資訊網(wǎng)——每日最新資訊28at.com

在這個例子中,我們定義了一個Counter類型,包含count字段和一個sync.Mutex。在Counter類型上定義了兩個方法: Increment()和Count()。這兩種方法都使用互斥鎖來確保一次只有一個goroutine可以訪問count字段。最后,我們創(chuàng)建1000個增加count字段的goroutine,在打印最終計數(shù)之前等待它們全部完成。btW28資訊網(wǎng)——每日最新資訊28at.com

6. WaitGroup

Go中的sync.WaitGroup類型提供了一種同步多個goroutine的簡單方法。WaitGroup在繼續(xù)之前等待一組goroutine完成,是協(xié)調多個goroutine執(zhí)行的有力工具,可以幫助我們確保在進入程序的下一步之前,所有goroutine都已完成。btW28資訊網(wǎng)——每日最新資訊28at.com

下面是一個使用WaitGroup的例子:btW28資訊網(wǎng)——每日最新資訊28at.com

btW28資訊網(wǎng)——每日最新資訊28at.com

在本例中,我們創(chuàng)建了一個WaitGroup和10個goroutine。每個goroutine休眠數(shù)秒,然后向控制臺打印一條消息。我們使用WaitGroup來確保在打印最終消息之前所有的goroutine都已經(jīng)完成。btW28資訊網(wǎng)——每日最新資訊28at.com

7. Context

Go中的context包提供了一種跨API邊界和進程之間攜帶截止日期、取消信號和其他請求作用域值的方法,是在并發(fā)系統(tǒng)中管理資源的強大工具,可以幫助我們避免常見問題(如goroutine泄漏)。btW28資訊網(wǎng)——每日最新資訊28at.com

下面是一個使用context的例子:btW28資訊網(wǎng)——每日最新資訊28at.com

func worker(ctx Context.context, wg *sync.WaitGroup) {  defer wg.Done()  for {    select {    case <- ctx.Done():      fmt.Println("Worker received cancel signal")      return    default:      fmt.Println("Worker is working...")      time.Sleep(1 * time.Second)    }  }}func main() {  ctx, cancel := context.WithCancel()  var wg sync.WaitGroup  wg.Add(1)  go worker(ctx, &wg)  time.Sleep(5 * time.Second)  cancel()  wg.Wait()  fmt.Println("All workers stopped")}

在這個例子中,我們定義了一個接受context.Context和sync.WaitGroup作為參數(shù)的worker函數(shù)。worker函數(shù)用select語句等待來自context的cancel信號或者在default中執(zhí)行某些工作。我們還定義了一個main函數(shù),該函數(shù)用context.WithCancel創(chuàng)建上下文,并啟動worker goroutine。等待5秒后cancel context,它會向worker goroutine發(fā)送cancel信號,讓它停止工作。在打印最終消息之前,我們用WaitGroup來等待worker goroutine結束。btW28資訊網(wǎng)——每日最新資訊28at.com

結論

總的來說,并發(fā)性是Go中的一個重要主題,并且該語言為處理并發(fā)系統(tǒng)提供了一組強大的工具。無論是構建web服務器、分布式系統(tǒng)還是簡單的命令行工具,了解Go的并發(fā)性對于構建健壯、可擴展、高效的程序都必不可少。btW28資訊網(wǎng)——每日最新資訊28at.com

本文鏈接:http://www.tebozhan.com/showinfo-26-23612-0.htmlGolang不可不知的七個并發(fā)概念

聲明:本網(wǎng)頁內容旨在傳播知識,若有侵權等問題請及時與本網(wǎng)聯(lián)系,我們將在第一時間刪除處理。郵件:2376512515@qq.com

上一篇: DDD領域驅動設計:為什么公司需要這種方法,誰使用它,它的本質是什么?

下一篇: 一起學Elasticsearch系列-Query DSL

標簽:
  • 熱門焦點
Top