欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

goFrame的隊列gqueue對比channel使用詳解

 更新時間:2022年06月09日 17:32:30   作者:王中陽Go  
這篇文章主要為大家介紹了goFrame的gqueue對比channel使用詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪

channel

首先明確一下channel的作用:用于go協(xié)程間的通信。

go語言最大的特點就是支持高并發(fā):goroutine和channel是支持高并發(fā)的重要組成部分。

單純地將函數(shù)并發(fā)執(zhí)行是沒有意義的。函數(shù)與函數(shù)間需要交換數(shù)據(jù)才能體現(xiàn)并發(fā)執(zhí)行函數(shù)的意義。

如果說 goroutine 是Go程序并發(fā)的執(zhí)行體,channel就是它們之間的連接。channel是可以讓一個 goroutine 發(fā)送特定值到另一個 goroutine 的通信機制。

另外要明確知道go的并發(fā)哲學,銘記這句原則:用通信來共享內存,而不要用共享內存來通信。

在搞清楚channel的作用之后我們再來研究GoFrame框架(下文簡稱gf)中gqueue的特點。

gqueue

概念

隊列 gqueue 動態(tài)大小的并發(fā)安全隊列

gqueue也可以設置為固定大小的隊列,固定大小時和標準庫channel沒區(qū)別。

簡單來說channel實現(xiàn)的功能gqueue也能實現(xiàn)。

使用場景:

gqueue是并發(fā)安全的,常用于多個goroutine數(shù)據(jù)通信且支持動態(tài)隊列大小的場景

代碼演示

package main
import (
   "fmt"
   "github.com/gogf/gf/container/gqueue"
   "github.com/gogf/gf/os/gtimer"
   "time"
)
func main() {
   //實例化gqueue
   q := gqueue.New()
   //數(shù)據(jù)生產者 每隔1秒想隊列寫入1條數(shù)據(jù)
   gtimer.SetInterval(time.Second, func() {
      nowStr := time.Now().String()
      q.Push(nowStr)
   })
   //3秒后關閉隊列
   gtimer.SetTimeout(time.Second*3, func() {
      fmt.Println("關閉隊列")
      q.Close()
   })
   // 消費者 不停的從隊列中取值輸出到終端中
   for {
      if v := q.Pop(); v != nil {
         fmt.Println("消費者接收:", v)
      } else {
         break
      }
   }
}
復制代碼

打印結果

優(yōu)勢

為什么不用標準庫的channel,要用gqueue呢?

  • gqueue的使用比channel更靈活,channel有隊列大小的限制,而gqueue隊列支持動態(tài)大小
  • channel的讀寫性能確實非常高,但是channel創(chuàng)建的時候需要初始化內存,初始化操作效率非常低;而gqueue的創(chuàng)建效率非常高,gqueue是動態(tài)創(chuàng)建內存。

底層實現(xiàn)

gqueue的底層實現(xiàn)是基于glist實現(xiàn)動態(tài)大小的特性,在隊列滿或者隊列空時讀取數(shù)據(jù)會產生阻塞。

glist是一個并發(fā)安全的鏈接,支持關閉并發(fā)安全的特性,當關閉并發(fā)安全的特性時和普通鏈表無異,在存儲和讀取數(shù)據(jù)時,不會產生阻塞。

阻止進程銷毀

select{}的作用可以阻止進程銷毀

package main
import (
   "fmt"
   "github.com/gogf/gf/container/gqueue"
   "github.com/gogf/gf/os/gtime"
   "github.com/gogf/gf/os/gtimer"
   "time"
)
func main() {
   //實例化隊列
   queue := gqueue.New()
   // 生產者每隔1秒鐘向隊列寫入一條數(shù)據(jù)
   gtimer.SetInterval(time.Second, func() {
      queue.Push(gtime.Now().String())
   })
   //消費者 常駐內存一直接收生產者的數(shù)據(jù)
   for {
      select {
      case v := <-queue.C: //C是 chan interface{}
         if v != nil {
            fmt.Println("消費者:", v)
         } else {
            return
         }
      }
   }
}
復制代碼

運行結果

如下圖所示,select{}可以阻止進程銷毀,gtimer一直在生產數(shù)據(jù),而for循環(huán)中的select一直在消費數(shù)據(jù)。

總結

以上就是goFrame的gqueue對比channel使用詳解的詳細內容,通過這篇文章,我們知道了channel的概念和作用。也知道了gqueue的底層實現(xiàn)和特點,以及gqueue和channel的對比。兩者各有什么特點,更多關于goFrame gqueue對比channel的資料請關注腳本之家其它相關文章!

相關文章

  • 詳解Golang時間處理的踩坑及解決

    詳解Golang時間處理的踩坑及解決

    在各個語言之中都有時間類型的處理,這篇文章主要和大家分享一下Golang進行時間處理時哪里最容易踩坑以及解決方法,需要的可以參考一下
    2023-01-01
  • Go獲取兩個時間點時間差的具體實現(xiàn)

    Go獲取兩個時間點時間差的具體實現(xiàn)

    本文主要介紹了Go獲取兩個時間點時間差的具體實現(xiàn),文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-04-04
  • Go標準庫-ServeMux的使用與模式匹配深入探究

    Go標準庫-ServeMux的使用與模式匹配深入探究

    這篇文章主要為大家介紹了Go標準庫-ServeMux的使用與模式匹配深入探究,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2024-01-01
  • Golang信號量設計實現(xiàn)示例詳解

    Golang信號量設計實現(xiàn)示例詳解

    這篇文章主要為大家介紹了Golang信號量設計實現(xiàn)示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-08-08
  • 詳解Go語言中用 os/exec 執(zhí)行命令的五種方法

    詳解Go語言中用 os/exec 執(zhí)行命令的五種方法

    這篇文章主要介紹了Go語言中用 os/exec 執(zhí)行命令的五種方法,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-11-11
  • go語言中的interface使用實例

    go語言中的interface使用實例

    這篇文章主要介紹了go語言中的interface使用實例,go語言中的interface是一組未實現(xiàn)的方法的集合,如果某個對象實現(xiàn)了接口中的所有方法,那么此對象就實現(xiàn)了此接口,需要的朋友可以參考下
    2015-05-05
  • Go語言面試題之select和channel的用法

    Go語言面試題之select和channel的用法

    金九銀十面試季到了(PS:貌似今年一年都是面試季),就業(yè)環(huán)境很差,導致從業(yè)人員不得不卷。本文將重點講解一下Go面試進階知識點之select和channel,需要的可以參考一下
    2022-09-09
  • Go語言同步等待組sync.WaitGroup結構體對象方法詳解

    Go語言同步等待組sync.WaitGroup結構體對象方法詳解

    這篇文章主要為大家介紹了Go語言同步等待組sync.WaitGroup結構體對象方法詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-08-08
  • golang中的并發(fā)和并行

    golang中的并發(fā)和并行

    這篇文章主要介紹了golang中的并發(fā)和并行用法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2021-05-05
  • 掌握Golang中的select語句實現(xiàn)并發(fā)編程

    掌握Golang中的select語句實現(xiàn)并發(fā)編程

    Golang中的select語句用于在多個通道間選擇可讀或可寫的操作,并阻塞等待其中一個通道進行操作。可以用于實現(xiàn)超時控制、取消和中斷操作等。同時,select語句支持default分支,用于在沒有任何通道可操作時執(zhí)行默認操作
    2023-04-04

最新評論