一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

腳本之家,腳本語言編程技術及教程分享平臺!
分類導航

Python|VBS|Ruby|Lua|perl|VBA|Golang|PowerShell|Erlang|autoit|Dos|bat|

服務器之家 - 腳本之家 - Golang - golang中for循環遍歷channel時需要注意的問題詳解

golang中for循環遍歷channel時需要注意的問題詳解

2020-05-15 10:06xialeistudio Golang

這篇文章主要給大家介紹了關于golang中for循環遍歷channel時需要注意的問題的相關資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧。

前言

for循環是Go語言唯一的循環結構,最近在做一個基于RabbitMQ的應用,由于官方的qos沒有golang的版本,所以出了一點問題。

問題代碼如下:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
_, ch, err := component.NewRabbitMQ()
if err != nil {
 panic(err)
}
if err := ch.Qos(10, 0, true); err != nil {
 panic(err)
}
msgs, err := ch.Consume("push", "", false, false, false, false, nil)
if err != nil {
 panic(err)
}
for m := range msgs {
 go func(d *amqp.Delivery) {
   defer func() { d.Ack(false) }
   // 處理消息
  }(&m)
 }

發現消費到10條消息,進程就退出了,但是exit code為0,表示系統是正常退出,由于做了日志記錄可以確定消費了10條,所以初步確定是qos相關問題。

排查過程

  • 首先是把d的tag打印出來,發現全部是一樣的,可以確定是重復的一條消息
  • 一開始想到可能是經典的go協程執行在for循環結束以后導致的,但是看我的代碼不屬于這種情況,有使用&m保證每一條消息都是不同循環傳入的。所以判斷可能是for循環的傳遞問題。
  • 確定方向之后開始寫了一個測試項目用來驗證我的想法是否正確。

測試代碼

?
1
2
3
4
5
6
7
8
9
10
11
12
package main
import "fmt"
func main() {
 ch := make(chan int, 10)
 for i := 0; i < 10; i++ {
 ch <- i
 }
 close(ch)
 for v := range ch {
 fmt.Println(&v)
 }
}

執行輸出

?
1
2
3
4
5
6
7
8
9
10
0xc420086008
0xc420086008
0xc420086008
0xc420086008
0xc420086008
0xc420086008
0xc420086008
0xc420086008
0xc420086008
0xc420086008

到這里才煥然大悟,for循環中,如果循環變量不是指針,那么每次的變量是同一個,不過值變了。,所以上例中的RabbitMQ go協程消費消息那里,需要直接傳遞值而不是指針,經過測試之后發現,問題確實解決了。

題外話

測試代碼那里,如果不close掉channel是會發生死鎖的,原因是 當for循環讀完channel的10個值之后會繼續嘗試讀取下一個,而由于channel為空又沒關閉,會一直阻塞形成死鎖

TOOD

研究RabbitMQ Consumer部分的源碼來看看消費channel被關閉的問題。

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,如果有疑問大家可以留言交流,謝謝大家對服務器之家的支持。

原文鏈接:https://www.ddhigh.com/2018/04/05/golang-for-over-channels.html

延伸 · 閱讀

精彩推薦
  • Golanggolang 通過ssh代理連接mysql的操作

    golang 通過ssh代理連接mysql的操作

    這篇文章主要介紹了golang 通過ssh代理連接mysql的操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧...

    a165861639710342021-03-08
  • GolangGolang通脈之數據類型詳情

    Golang通脈之數據類型詳情

    這篇文章主要介紹了Golang通脈之數據類型,在編程語言中標識符就是定義的具有某種意義的詞,比如變量名、常量名、函數名等等,Go語言中標識符允許由...

    4272021-11-24
  • Golanggo日志系統logrus顯示文件和行號的操作

    go日志系統logrus顯示文件和行號的操作

    這篇文章主要介紹了go日志系統logrus顯示文件和行號的操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧...

    SmallQinYan12302021-02-02
  • Golanggolang如何使用struct的tag屬性的詳細介紹

    golang如何使用struct的tag屬性的詳細介紹

    這篇文章主要介紹了golang如何使用struct的tag屬性的詳細介紹,從例子說起,小編覺得挺不錯的,現在分享給大家,也給大家做個參考。一起跟隨小編過來看...

    Go語言中文網11352020-05-21
  • GolangGolang中Bit數組的實現方式

    Golang中Bit數組的實現方式

    這篇文章主要介紹了Golang中Bit數組的實現方式,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧...

    天易獨尊11682021-06-09
  • Golanggolang的httpserver優雅重啟方法詳解

    golang的httpserver優雅重啟方法詳解

    這篇文章主要給大家介紹了關于golang的httpserver優雅重啟的相關資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,...

    helight2992020-05-14
  • Golanggo語言制作端口掃描器

    go語言制作端口掃描器

    本文給大家分享的是使用go語言編寫的TCP端口掃描器,可以選擇IP范圍,掃描的端口,以及多線程,有需要的小伙伴可以參考下。 ...

    腳本之家3642020-04-25
  • Golanggolang json.Marshal 特殊html字符被轉義的解決方法

    golang json.Marshal 特殊html字符被轉義的解決方法

    今天小編就為大家分享一篇golang json.Marshal 特殊html字符被轉義的解決方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧 ...

    李浩的life12792020-05-27
主站蜘蛛池模板: 1024视频色版在线网站 | 高h短篇辣肉各种姿势bl | 欧美日韩一区二区三区免费不卡 | 欧美高清在线精品一区 | 免费永久观看美女视频网站网址 | 精品亚洲永久免费精品 | 大学生按摩黄a级中文片 | 日韩在线1 | 四虎国产欧美成人影院 | 免费一区二区 | 娇喘嗯嗯 轻点啊视频福利 九九九九在线精品免费视频 | ova巨公主催眠1在线观看 | juliaann丝袜精品系列 | 秋霞午夜视频在线观看 | 人成网站在线观看 | 免费高清视频在线观看 | 国产成人综合亚洲亚洲欧美 | 海绵宝宝第二季全集免费观看 | 欧美2区 | 99久久香蕉国产线看观香 | 男人曰女人 | 黑帮少爷爱上我第8集在线观看 | 久久亚洲精品AV成人无码 | 久久五月综合婷婷中文云霸高清 | 亚洲同性男男gay1069 | 日本卡一卡2卡3卡4精品卡无人区 | 动漫精品一区二区三区3d | 国产精品欧美亚洲韩国日本99 | 成人男女啪啪免费观看网站 | 精品免费久久久久久成人影院 | 我被男人下药添得好爽 | 天天白天天谢天天啦 | 欧美日韩三区 | 欧美人曾交 | 日本在线播放 | 欧美最新在线 | 亚洲是图你懂的 | 干美女在线视频 | 非洲一级毛片又粗又长aaaa | 亚洲精品青青草原avav久久qv | chinesemature精品 chinesefree普通对话 |