这篇文章将为大家详细讲解有关golang中Goroutine顺序输出方式的示例分析,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。golang适合做什么golang可以做服务器端开发,但golang很适合做
这篇文章将为大家详细讲解有关golang中Goroutine顺序输出方式的示例分析,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。
golang可以做服务器端开发,但golang很适合做日志处理、数据打包、虚拟机处理、数据库代理等工作。在网络编程方面,它还广泛应用于WEB应用、api应用等领域。
range字符串,使用goroutine打印
for _, v := range str { go func() { fmt.Println(string(v)) }()}
输出:
5
5
5
5
5
for _, c := range str{ ch := make(chan rune) go func(ch <-chan rune) { key := <-ch fmt.Println(string(key)) }(ch) ch <- c }
输出:
1
2
3
4
5
补充:golang goroutine顺序循环打印ABC
分别使用sync.WaitGroup和context
package mainimport ("fmt""sync")//控制循环次数var count = 5func main() {wg := sync.WaitGroup{}chanA := make(chan struct{}, 1)chanB := make(chan struct{}, 1)chanC := make(chan struct{}, 1)chanA <- struct{}{}wg.Add(3)go printA(&wg, chanA, chanB)go printB(&wg, chanB, chanC)go printC(&wg, chanC, chanA)wg.Wait()}func printA(wg *sync.WaitGroup, chanA, chanB chan struct{}) {defer wg.Done()for i := 0; i < count; i++ {<-chanAfmt.Println("A")chanB <- struct{}{}}}func printB(wg *sync.WaitGroup, chanB, chanC chan struct{}) {defer wg.Done()for i := 0; i < count; i++ {<-chanBfmt.Println("B")chanC <- struct{}{}}}func printC(wg *sync.WaitGroup, chanC, chanA chan struct{}) {defer wg.Done()for i := 0; i < count; i++ {<-chanCfmt.Println("C")chanA <- struct{}{}}}
package mainimport ("context""fmt""time")func main() {chanA := make(chan struct{}, 1)chanB := make(chan struct{}, 1)chanC := make(chan struct{}, 1)chanA <- struct{}{}ctx1, cancel1 := context.WithCancel(context.Background())ctx2, cancel2 := context.WithCancel(context.Background())ctx3, cancel3 := context.WithCancel(context.Background())go printA(ctx1, chanA, chanB)go printB(ctx2, chanB, chanC)go printC(ctx3, chanC, chanA)time.Sleep(100 * time.Microsecond)cancel1()cancel2()cancel3()}func printA(ctx context.Context, chanA, chanB chan struct{}) {for {select {case <-ctx.Done():fmt.Println("cancel by parent") // 不会输出returncase <-chanA:fmt.Println("A")chanB <- struct{}{}}}}func printB(ctx context.Context, chanB, chanC chan struct{}) {for {select {case <-ctx.Done():fmt.Println("cancel by parent") // 不会输出returncase <-chanB:fmt.Println("B")chanC <- struct{}{}}}}func printC(ctx context.Context, chanC, chanA chan struct{}) {for {select {case <-ctx.Done():fmt.Println("cancel by parent") // 不会输出returncase <-chanC:fmt.Println("C")chanA <- struct{}{}}}}
关于“golang中goroutine顺序输出方式的示例分析”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,使各位可以学到更多知识,如果觉得文章不错,请把它分享出去让更多的人看到。
--结束END--
本文标题: golang中goroutine顺序输出方式的示例分析
本文链接: https://www.lsjlt.com/news/275451.html(转载时请注明来源链接)
有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341
下载Word文档到电脑,方便收藏和打印~
2024-04-05
2024-04-05
2024-04-05
2024-04-05
2024-04-05
2024-04-05
2024-04-05
2024-04-05
回答
回答
回答
回答
回答
回答
回答
回答
回答
回答
0