goroutine
已收录文章:23篇
-
问题内容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 收藏
-
学习刘丹冰《8小时转职golang工程师》,本节都是原理 单进程操作系统 早期的单进程操作系统,可以理解为只有一个时间轴,CPU顺序执行每一个进程/线程,这种顺序执行的方式,CPU同一时间智331 收藏
-
问题内容最近在看golang 的 协程,一直很疑问如何开启多个协程网上的教程或者demo就是直接 通过 go func() 来开启携程,那么开启多个协程该怎么开启?正确答案 100个协程的开启姿势: package main322 收藏
-
突然想到了之前一直没留意的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语言中goroutine和WaitGroup如何使用”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Go语言中goroutine和WaitGroup如何使用240 收藏
-
使用通道接收数据 在上一篇文章中介绍了通道以及使用通道发送数据,本篇接着了解通道的基本内容,如何使用通道接收数据; 通道的接收同样使用"<-"操作符; 使用通道接收数据的221 收藏
-
问题内容 Golangpackage main import "fmt" var quit chan int var glo int func test() { fmt.Println(glo) } func main() { glo = 0 n := 10000 quit = make(chan int, n) go test() for { quit <- 1 glo++ } }217 收藏