Golang 中 Goroutines 和 Channels 的高级用法
在 Golang 的并发编程中,Goroutines 和 Channels 是两个非常重要的概念。Goroutines 是轻量级线程,可以并发执行,而 Channels 则是 Goroutines 之间通信的机制。在这篇文章中,我们将探讨 Golang 中 Goroutines 和 Channels 的高级用法,并通过代码示例来说明。
一、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 } } } }
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 的高级用法
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) }
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 的高级用法的详细内容。更多信息请关注PHP中文网其他相关文章!