在Go语言中,实现并发编程主要依赖于Goroutines和Channels。Goroutines是Go语言中的轻量级线程,它们在同一个操作系统线程上运行,但是它们之间有独立的栈空间。Channels则用于在Goroutines之间传递数据。
以下是一个简单的示例,展示了如何在Ubuntu上使用Go语言实现并发编程:
首先,确保你已经安装了Go语言。如果没有,请访问Go官方网站(https://golang.org/dl/)下载并安装。
创建一个名为main.go
的文件,并输入以下代码:
package main
import (
"fmt"
"sync"
"time"
)
func printNumbers(wg *sync.WaitGroup) {
defer wg.Done() // 当函数执行完毕时,调用Done()方法通知WaitGroup
for i := 1; i <= 5; i++ {
time.Sleep(1 * time.Second) // 暂停1秒
fmt.Printf("Number: %d\n", i)
}
}
func main() {
var wg sync.WaitGroup // 创建一个WaitGroup实例
wg.Add(1) // 为WaitGroup添加一个任务
go printNumbers(&wg) // 启动一个新的Goroutine来执行printNumbers函数
wg.Wait() // 等待所有任务完成
fmt.Println("All numbers printed")
}
main.go
文件的目录,并运行以下命令来编译并运行程序:go run main.go
在这个示例中,我们使用了sync.WaitGroup
来确保主Goroutine等待其他Goroutines完成任务。printNumbers
函数在一个新的Goroutine中运行,每隔1秒打印一个数字。当所有数字都打印完毕后,主Goroutine会继续执行并输出"All numbers printed"。