jjzjj

sync_synchronize

全部标签

go - sync.WaitGroup传值引起的死锁?

有2种写重现的方法:第一种方式,程序干净退出。funcrecurse(depthint,wg*sync.WaitGroup){deferwg.Done()ifdepth==0{return}wg.Add(1)gorecurse(depth-1,wg)}funcmain(){wg:=sync.WaitGroup{}wg.Add(1)gorecurse(3,&wg)wg.Wait()}第二种方式,程序给出“fatalerror:allgoroutinesareasleep-deadlock!”funcrecurse(depthint,wgsync.WaitGroup){deferwg.Do

concurrency - sync.WaitGroup 不等待

可能是我看不到明显的东西,我做错了什么:funcprintSize(listOfUrls[]string){varwgsync.WaitGroupwg.Add(len(listOfUrl))for_,myurl:=range(listOfUrls){gofunc(){body:=getUrlBody(myurl)fmt.Println(len(body))wg.Done()}()}wg.Wait()}如果我删除wg并继续,我会正确收到每个url正文的大小。如果我像上面那样做,它几乎会立即打印出零。getUrlBody()有时需要几分钟才能执行。回答评论:可以肯定的是,我也以这种方式尝试

golang sync.WaitGroup 在 Linux 上没有完成

我有ping功能,它在Windows上运行良好,但在Linux上却不行。在Linux上,它会ping几台主机并停止(不退出)。funcmain(){...wg.Add(len(hosts))for_,ip:=rangehosts{goping(ip,&wg,os)}wg.Wait()...}我可以在Windows上ping数百台主机,但在Linux上不行。看https://github.com/irom77/go-public/blob/master/gping/main.go对于整个事情funcping(ipstring,wg*sync.WaitGroup,osstring){_,e

go - 为什么 `sync.WaitGroup` 无法完成?

这是我的代码:packagemainimport("bytes""crypto/md5""encoding/hex""encoding/json""fmt""io/ioutil""log""net/http""runtime""sync")typeDatastruct{Linkstring`json:"url"`}typeResultstruct{Codeuint32Msgstring`json:"msg"`DataData`json:"data"`}const(URL="http://qiye.wxsdc.ediankai.com/api/v1/suppliers/1/staff/1

go - sync.Map 是原子的吗?我主要是指加载、存储、加载或存储、删除

作为tile,我指的是Go包sync.Map,它的功能可以被认为是原子的吗?主要是Load、Store、LoadOrStore和Delete函数。我也建立了一个简单的例子goplayground,是否保证只有一个goroutine可以进入代码范围15-17?正如我的测试似乎可以保证。请帮忙解释一下。 最佳答案 godocsync包的页面说:“Map类似于Gomap[interface{}]interface{},但多个goroutine并发使用是安全的,无需额外的锁定或协调。”此语句保证不需要额外的互斥锁或跨goroutine同步。

Go的sync.Map加载结果无法添加

我只是想在sync.Map上做一些简单的CREATE或ADDgore>:importsyncgore>varsmsync.Mapgore>sm.Store(12345,1)gore>result,ok:=sm.Load(12345)1truegore>newr:=result+1#command-line-arguments/var/folders/kl/n95_c8j15wn1784jmsq08mq80000gn/T/112740772/gore_session.go:21:17:invalidoperation:result+1(mismatchedtypesinterface{}

go - Confluent Kafka Golang 客户端生产者 "Broker: Not enough in-sync replicas"

我正在尝试测试生产者使用Golang客户端向kafka集群上的主题写入消息。这可以很好地写入本地集群上的主题,我只是复制并粘贴了他们的示例代码githubrepo.packagemainimport("fmt""gopkg.in/confluentinc/confluent-kafka-go.v1/kafka")funcmain(){p,err:=kafka.NewProducer(&kafka.ConfigMap{"bootstrap.servers":"localhost"})iferr!=nil{panic(err)}deferp.Close()//Deliveryreporth

go - 为什么 gorilla websocket 聊天示例没有发现必须使用 sync.RWMutex 来访问和编辑 map ?

在聊天示例中有一个名为hub.go的文件。https://github.com/gorilla/websocket/blob/master/examples/chat/hub.go我对该文件做了一些修改,它看起来像这样:typehubstruct{//Registeredconnections.connectionsmap[int64]*connectionsync.RWMutex//Inboundmessagesfromtheconnections.broadcastchan[]byte//Registerrequestsfromtheconnections.registerchan

go - 在两个单独的 goroutine 中比较两个 slice 并使用 sync.Waitgroup 时挂起 goroutines

我正在学习goroutines,并且在两个goroutines中将两个slice相互比较,这是在无限循环中永远比较它,这可能不是最好的例子,我无法弄清楚为什么挂了。for;;{varwgsync.WaitGroupwg.Add(2)goFindinFirst(&Arr1,&Arr2,AddChan,&wg)goFindinSecond(&Arr2,&Arr1,DelChan,&wg)counter:=0for;;{select{caseAdd,ok:=FindinFirst函数是funcFindinFirst(Arr1,Arr2*[]string,AddChanchanstring,w

golang 使用结构本身为 sync.Mutex 和 sync.Cond 初始化成员

这是代码:typesomeThingstruct{sync.Mutexcv*sync.Condnumint}funcNewSomething()*someThing{//howdoyoudothis?return&someThing{cv:sync.NewCond(sync.Mutex)}}此代码编译失败:sync.Mutex(type)isnotanexpression所以基本上问题是如何在初始化时引用结构本身(因为它有一个嵌入式成员sync.Mutex)?(例如,c++有this)。 最佳答案 可以先新建一个实例,然后再引用嵌入