【Go程序实现】go如何用两个协程交替打印出123456

在 Go 中,使用两个协程(goroutine)交替打印 123456 的核心在于同步机制流程控制。我们可以借助 channel 来实现两个 goroutine 之间的协作,确保它们按顺序交替打印。


✅ 实现目标

  • 使用两个 goroutine 交替打印数字 1 到 6;
  • 输出顺序为:1 → 2 → 3 → 4 → 5 → 6;
  • 每个 goroutine 负责打印一半的数字(比如,一个打印奇数,一个打印偶数);
  • 打印结束后程序应正确退出。

🛠 实现思路

  1. 共享计数器:使用 atomic 包管理一个共享的计数器变量,确保并发读写安全。
  2. 通道通信:使用两个无缓冲的 channel(aChanbChan)作为“令牌”,控制 goroutine 的执行顺序。
  3. 流程控制
    • 每个 goroutine 在接收到 channel 信号后打印当前数字;
    • 打印完成后,将“令牌”传递给另一个 goroutine;
    • 当数字达到 6 时,两个 channel 被关闭,goroutine 退出循环;
    • 主函数通过 WaitGroup 等待两个 goroutine 完成。

🧩 示例代码

package main

import (
	"fmt"
	"sync/atomic"
)

func main() {
   
   
	var counter int32 = 1
	aChan := make(chan bool)
	bChan 
使用协程交替打印字母和数字可以利用 Go 语言中的通道(channel)和 `sync.WaitGroup` 来实现,以下是几种常见的实现方法: ### 方法一:使用无缓冲通道和 `sync.WaitGroup` ```go package main import ( "fmt" "sync" ) func main() { letter, number := make(chan bool), make(chan bool) wait := sync.WaitGroup{} go func() { i := 1 for { select { case <-number: fmt.Print(i) i++ fmt.Print(i) i++ letter <- true } } }() wait.Add(1) go func() { i := 'A' for { select { case <-letter: if i >= 'Z' { wait.Done() return } fmt.Print(string(i)) i++ fmt.Print(string(i)) i++ number <- true } } }() fmt.Println("程序先执行此句输。") number <- true wait.Wait() fmt.Println("\n程序最后执行此句输。") } ``` 此方法使用两个无缓冲通道 `letter` 和 `number` 来控制两个协程交替执行,`sync.WaitGroup` 用于等待子协程完成。一个协程负责打印数字,另一个协程负责打印字母,通过通道的发送和接收操作来实现交替打印 [^1]。 ### 方法二:使用有缓冲通道 ```go package main import ( "fmt" "time" ) func ChannelFunc() { strChan := make(chan int, 1) numChan := make(chan int, 1) strChan <- 0 go func() { for i := 65; i <= 90; i++ { <-strChan fmt.Printf("%v ", string(rune(i))) numChan <- i } return }() go func() { for i := 1; i <= 26; i++ { <-numChan fmt.Printf("%v ", i) strChan <- i } return }() time.Sleep(1 * time.Second) fmt.Println() } func main() { ChannelFunc() } ``` 该方法使用两个有缓冲的通道 `strChan` 和 `numChan` 来控制两个协程打印顺序,一个协程打印字母,另一个协程打印数字,通过通道的发送和接收操作实现交替打印 [^4]。 ### 方法三:使用无缓冲通道和 `sync.WaitGroup` 打印奇数和偶数加 1 ```go package main import ( "fmt" "sync" ) func main() { var wg sync.WaitGroup ch1 := make(chan int) ch2 := make(chan int) wg.Add(2) go func() { defer wg.Done() for i := 1; i <= 100; i += 2 { ch1 <- i fmt.Println("Goroutine 1:", i) <-ch2 } close(ch1) }() go func() { defer wg.Done() for i := range ch1 { fmt.Println("Goroutine 2:", i+1) ch2 <- i } close(ch2) }() wg.Wait() } ``` 此方法使用 `sync.WaitGroup` 来控制两个协程的执行完成,通过两个无缓冲通道 `ch1` 和 `ch2` 实现信号的传递和顺序打印,一个协程打印奇数,另一个协程打印奇数加 1 的结果 [^5]。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值