Golang 中 Goroutines 和 Channels 的高级用法
时间:2023-08-14 19:46:40 164浏览 收藏
IT行业相对于一般传统行业,发展更新速度更快,一旦停止了学习,很快就会被行业所淘汰。所以我们需要踏踏实实的不断学习,精进自己的技术,尤其是初学者。今天golang学习网给大家整理了《Golang 中 Goroutines 和 Channels 的高级用法》,聊聊,我们一起来看看吧!
Golang 中 Goroutines 和 Channels 的高级用法
在 Golang 的并发编程中,Goroutines 和 Channels 是两个非常重要的概念。Goroutines 是轻量级线程,可以并发执行,而 Channels 则是 Goroutines 之间通信的机制。在这篇文章中,我们将探讨 Golang 中 Goroutines 和 Channels 的高级用法,并通过代码示例来说明。
一、Goroutines 的高级用法
- 可以通过 select 语句来实现 Goroutines 的多路复用。下面的代码示例中,我们创建了两个 Goroutines,分别用于计算斐波那契数列和阶乘。通过 select 语句,我们可以等待两个 Goroutines 同时完成,并将计算结果打印出来。
package main import ( "fmt" ) func fibonacci(n int, c chan<- int) { x, y := 0, 1 for i := 0; i < n; i++ { c <- x x, y = y, x+y } close(c) } func factorial(n int, c chan<- int) { result := 1 for i := 1; i <= n; i++ { result *= i } c <- result close(c) } func main() { fibChan := make(chan int) factChan := make(chan int) go fibonacci(10, fibChan) go factorial(5, factChan) for { select { case fib, ok := <-fibChan: if ok { fmt.Println("Fibonacci:", fib) } else { fibChan = nil } case fact, ok := <-factChan: if ok { fmt.Println("Factorial:", fact) } else { factChan = nil } default: if fibChan == nil && factChan == nil { return } } } }
- 可以通过 WaitGroup 来等待 Goroutines 的完成。WaitGroup 是一个计数器,可以用于等待一组 Goroutines 的结束。下面的代码示例中,我们创建了两个 Goroutines,分别用于计算斐波那契数列和阶乘。通过 sync.WaitGroup,我们可以等待两个 Goroutines 同时完成。
package main import ( "fmt" "sync" ) func fibonacci(n int, c chan<- int, wg *sync.WaitGroup) { defer wg.Done() x, y := 0, 1 for i := 0; i < n; i++ { c <- x x, y = y, x+y } close(c) } func factorial(n int, c chan<- int, wg *sync.WaitGroup) { defer wg.Done() result := 1 for i := 1; i <= n; i++ { result *= i } c <- result close(c) } func main() { fibChan := make(chan int) factChan := make(chan int) var wg sync.WaitGroup wg.Add(2) go fibonacci(10, fibChan, &wg) go factorial(5, factChan, &wg) go func() { wg.Wait() close(fibChan) close(factChan) }() for { select { case fib, ok := <-fibChan: if ok { fmt.Println("Fibonacci:", fib) } else { fibChan = nil } case fact, ok := <-factChan: if ok { fmt.Println("Factorial:", fact) } else { factChan = nil } default: if fibChan == nil && factChan == nil { return } } } }
二、Channels 的高级用法
- 可以通过设置缓冲区大小来控制 Channel 的阻塞行为。默认情况下,Channel 是无缓冲的,即发送和接收都会阻塞直到对方准备好。我们可以通过 make 函数的第二个参数来设置缓冲区大小。下面的代码示例中,我们创建了一个拥有缓冲区大小为 3 的 Channel,并向其中发送了 3 个值。由于缓冲区未满,发送不会阻塞。
package main import ( "fmt" ) func main() { ch := make(chan int, 3) ch <- 1 ch <- 2 ch <- 3 fmt.Println(<-ch) fmt.Println(<-ch) fmt.Println(<-ch) }
- 可以通过 range 关键字来迭代 Channel。range 关键字可以用于迭代 Channel 中的值,当 Channel 关闭时,迭代会自动结束。下面的代码示例中,我们创建了一个计数器 Goroutines,并向一个无缓冲的 Channel 中发送了 5 个值。在 main 函数中,我们通过 range 关键字来迭代 Channel 中的值,并将其打印出来。当 Channel 关闭后,range 循环会自动结束。
package main import ( "fmt" "time" ) func counter(ch chan<- int) { for i := 1; i <= 5; i++ { ch <- i time.Sleep(time.Second) } close(ch) } func main() { ch := make(chan int) go counter(ch) for val := range ch { fmt.Println(val) } }
综上所述,Golang 中的 Goroutines 和 Channels 提供了强大且灵活的并发编程能力。通过选择语句、WaitGroup、缓冲区和 range 关键字等高级用法,我们可以更好地控制 Goroutines 和 Channels 的行为。希望本文所给出的代码示例能够帮助读者更好地理解和应用这些高级用法。
本篇关于《Golang 中 Goroutines 和 Channels 的高级用法》的介绍就到此结束啦,但是学无止境,想要了解学习更多关于Golang的相关知识,请关注golang学习网公众号!
相关阅读
更多>
-
505 收藏
-
502 收藏
-
501 收藏
-
501 收藏
-
501 收藏
最新阅读
更多>
-
103 收藏
-
424 收藏
-
186 收藏
-
380 收藏
-
403 收藏
-
174 收藏
-
262 收藏
-
217 收藏
-
320 收藏
-
276 收藏
-
101 收藏
-
379 收藏
课程推荐
更多>
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 542次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 508次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 497次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 484次学习