goroutine
已收录文章:27篇
-
问题内容Go初学者,在学习 @无闻 大神的 《Go编程基础(视频)》 的第14课并发时,对其中的示例代码有疑问,本地执行的输出结果不符合预期。运行环境$ go version go version go1.17.2 darwin/arm64问题499 收藏
-
参考Go的CSP并发模型实现:M, P, G Go语言是为并发而生的语言,Go语言是为数不多的在语言层面实现并发的语言。 并发(concurrency):多个任务在同一段时间内运行。 并行(parallellism):多个任务在同451 收藏
-
问题内容接触go没多久,在网上看了看tcp聊天服务器,大概实现就是:遇到有用户连接就直接开一个goruntine,这样的性能是否算高呢?假设只是一台4核8gb机器。大概能启动多少goruntine?怎么样能充分433 收藏
-
背景 最近在学习MIT的分布式课程6.824的过程中,使用Go实现Raft协议时遇到了一些问题。分享出来供大家参考学习,下面话不多说了,来一起看看详细的介绍吧。 参见如下代码: for i := 0; i <403 收藏
-
从 goroutine 数量持续上涨的现象出发,用 pprof、runtime 指标、阻塞栈和 context 取消链路逐层定位泄漏原因,并给出修复与反向验证清单。392 收藏
-
学习刘丹冰《8小时转职golang工程师》,本节都是原理 单进程操作系统 早期的单进程操作系统,可以理解为只有一个时间轴,CPU顺序执行每一个进程/线程,这种顺序执行的方式,CPU同一时间智331 收藏
-
问题内容最近在看golang 的 协程,一直很疑问如何开启多个协程网上的教程或者demo就是直接 通过 go func() 来开启携程,那么开启多个协程该怎么开启?正确答案 100个协程的开启姿势: package main322 收藏
-
本文解释 Go for range 中 goroutine 打印错值的问题,区分 Go 1.22 新循环变量语义和旧模块行为,并给出版本检查、代码排查、兼容写法和验证清单。315 收藏
-
突然想到了之前一直没留意的for循环中开goroutine的执行顺序问题,就找了段代码试了试,试了几次后发现几个有意思的地方,我暂时没有精力往更深处挖掘,希望有golang大神能简单说一说这几个296 收藏
-
range字符串,使用goroutine打印 因为goroutine随机执行 for _, v := range str { go func() { fmt.Println(string(v)) }() } 输出: 5 5 5 5 5 可以使用chan顺序输出 for _, c := range str{ ch276 收藏
-
并发(concurrency): 指在同一时刻只能有一条指令执行,但多个进程指令被快速的轮换执行,使得在宏观上具有多个进程同时执行的效果,但在微观上并不是同时执行的,只是把时间分成若干段,241 收藏
-
用生产代码视角讲清 Go channel 谁来关闭、close 后发送 panic、多发送方协调、range 退出、context 取消和 worker 收尾写法。240 收藏