在Go语言(Golang)中,实现并发主要依赖于两个关键字:goroutine 和 channel。goroutine 是Go语言中的轻量级线程,而 channel 则用于在 goroutine 之间传递数据。
以下是一个简单的示例,展示了如何在Linux上使用Golang实现并发:
package main
import (
	"fmt"
	"time"
)
func printNumbers() {
	for i := 1; i <= 5; i++ {
		fmt.Printf("Number: %d\n", i)
		time.Sleep(1 * time.Second)
	}
}
func printLetters() {
	for i := 'A'; i <= 'E'; i++ {
		fmt.Printf("Letter: %c\n", i)
		time.Sleep(1 * time.Second)
	}
}
func main() {
	go printNumbers() // 创建一个新的goroutine来执行printNumbers函数
	go printLetters() // 创建一个新的goroutine来执行printLetters函数
	time.Sleep(6 * time.Second) // 等待足够的时间,以便两个goroutine都能完成执行
	fmt.Println("Done")
}
在这个示例中,我们定义了两个函数:printNumbers 和 printLetters。我们在 main 函数中使用 go 关键字创建了两个新的 goroutine 来并发地执行这两个函数。time.Sleep 函数用于让主线程等待足够的时间,以便两个 goroutine 都能完成执行。
要在Linux上运行此程序,请将代码保存到一个文件(例如 concurrency.go),然后在终端中运行以下命令:
go run concurrency.go
这将编译并运行程序,您将看到数字和字母交替打印出来,表明两个函数正在并发执行。