您的位置:首页 >Ubuntu中Golang并发编程怎么写
发布于2026-05-02 阅读(0)
扫一扫,手机访问
想在Ubuntu系统里玩转Golang的并发编程?其实核心就是掌握好goroutines和channels这两个原语。下面通过一个具体的例子,带你走一遍完整的流程,看看如何让多个任务在Ubuntu环境下协同工作。

首先,确保你的Ubuntu系统已经安装了Golang。如果还没安装,直接去官网(https://golang.org/dl/)下载对应版本的安装包,按照指引完成安装即可。
接下来,创建一个新的Go文件,比如就叫它 main.go,然后用你喜欢的文本编辑器打开它。
在 main.go 文件中,输入以下代码:
package main
import (
"fmt"
"sync"
"time"
)
func main() {
var wg sync.WaitGroup
// 创建一个channel,用于在goroutines之间传递数据
dataChan := make(chan int)
// 启动一个goroutine,用于向channel发送数据
wg.Add(1)
go func() {
defer wg.Done()
for i := 0; i < 5; i++ {
dataChan <- i
time.Sleep(1 * time.Second)
}
close(dataChan)
}()
// 启动另一个goroutine,用于从channel接收数据并处理
wg.Add(1)
go func() {
defer wg.Done()
for data := range dataChan {
fmt.Println("Received data:", data)
}
}()
// 等待所有goroutines完成
wg.Wait()
fmt.Println("All goroutines finished.")
}
这段代码做了几件关键的事:它使用 sync.WaitGroup 来确保主程序等待所有“子任务”完成。同时,创建了一个名为 dataChan 的通道(channel),作为goroutines之间的数据传输管道。代码启动了两个goroutine:一个负责每隔一秒向通道发送一个数字,发送完毕后会关闭通道;另一个则持续从通道接收数据并打印出来。这种“生产者-消费者”模式是并发编程中的经典场景。
保存好文件后,打开终端,切换到文件所在目录,运行下面这条命令:
go run main.go
现在,观察终端的输出。你会看到两个goroutine在同时运行:一个在后台默默发送数据,另一个则实时接收并打印出这些数据。整个过程是并发进行的,而不是顺序执行。
通过这个简单的示例,你应该对在Ubuntu中使用Golang进行并发编程有了一个直观的感受。当然,这只是个起点。你可以基于这个模式,修改和扩展代码,来实现更复杂的并发逻辑,比如处理更多任务、使用带缓冲的通道,或者引入更精细的同步机制。关键在于理解goroutine的轻量和channel的通信能力,剩下的就是你的想象力了。
售后无忧
立即购买>office旗舰店
售后无忧
立即购买>office旗舰店
售后无忧
立即购买>office旗舰店
售后无忧
立即购买>office旗舰店
正版软件
正版软件
正版软件
正版软件
正版软件
1
2
3
7
9