在Go语言(Golang)中处理并发,核心武器就是内置的goroutines和channels。goroutines可以理解为轻量级的线程,让你在程序中同时运行多个任务;而channels则是它们在协程间传递数据的“管道”。这篇文章就带你在Debian系统上走一遍Golang并发的实战流程,从环境搭建到代码运行,一步步来。

首先,把Go语言环境装好。Debian下一条命令就能搞定:
sudo apt-get update
sudo apt-get install golang-go
环境就绪后,创建一个Go程序文件,比如叫main.go。然后在该文件里导入必要的包:fmt用于输出,sync用于并发同步。这是标准操作,但别小看这一步——很多新手就是因为漏了sync导致goroutine还没跑完程序就退出了。
package main
import (
"fmt"
"sync"
)
接下来是真正有意思的部分:创建一个goroutine。我们用go关键字启动一个函数。写一个printNumbers函数,让它打印1到10的数字,同时在主函数里通过sync.WaitGroup来等待这个goroutine执行完毕。注意看defer wg.Done()这行,它确保goroutine结束时通知WaitGroup,否则主线程会一直阻塞。
func printNumbers(wg *sync.WaitGroup) {
defer wg.Done()
for i := 1; i <= 10; i++ {
fmt.Println(i)
}
}
func main() {
var wg sync.WaitGroup
wg.Add(1)
go printNumbers(&wg)
wg.Wait()
}
代码写完后,在终端用go run main.go运行。这个程序会启动一个goroutine来打印数字,主线程则老老实实等着它干完活再退出。你可以试着把wg.Wait()注释掉看看效果——会发现程序往往只打印了部分数字就结束了,因为主线程跑得太快,根本不等goroutine。
当然,这只是最简单的并发示例。实际项目中你可能需要启动几十上百个goroutine,并用channels在它们之间传递数据、协调工作流。掌握了这个基础,剩下的就是根据业务需求玩出更多花样了。
