在Ubuntu上使用Golang的并发特性主要涉及到goroutines和channels。以下是一些基本步骤和示例,帮助你在Ubuntu上使用Golang的并发特性:
首先,确保你已经在Ubuntu上安装了Golang。如果没有安装,可以通过以下命令安装:
sudo apt update
sudo apt install golang-go
验证安装:
go version
创建一个新的Go文件:
nano hello.go
编写代码:
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 main() {
go printNumbers() // 启动一个新的goroutine
fmt.Println("Main function is running")
time.Sleep(6 * time.Second) // 等待goroutine完成
}
运行程序:
go run hello.go
Channels是Golang中用于goroutines之间通信和同步的主要机制。以下是一个使用channels的示例:
创建一个新的Go文件:
nano channels.go
编写代码:
package main
import (
"fmt"
"time"
)
func produce(ch chan<- int) {
for i := 1; i <= 5; i++ {
ch <- i // 将数据发送到channel
time.Sleep(1 * time.Second)
}
close(ch) // 关闭channel
}
func consume(ch <-chan int) {
for num := range ch {
fmt.Printf("Received: %d\n", num)
}
}
func main() {
ch := make(chan int)
go produce(ch) // 启动生产者goroutine
go consume(ch) // 启动消费者goroutine
time.Sleep(6 * time.Second) // 等待goroutines完成
}
运行程序:
go run channels.go
sync.WaitGroup是Golang中用于等待一组goroutines完成的机制。以下是一个使用sync.WaitGroup的示例:
创建一个新的Go文件:
nano waitgroup.go
编写代码:
package main
import (
"fmt"
"sync"
"time"
)
func printNumbers(wg *sync.WaitGroup) {
defer wg.Done() // 确保在函数结束时调用Done()
for i := 1; i <= 5; i++ {
fmt.Printf("Number: %d\n", i)
time.Sleep(1 * time.Second)
}
}
func main() {
var wg sync.WaitGroup
wg.Add(1) // 增加WaitGroup的计数器
go printNumbers(&wg)
wg.Wait() // 等待所有goroutines完成
fmt.Println("All goroutines are done")
}
运行程序:
go run waitgroup.go
通过这些示例,你应该能够在Ubuntu上使用Golang的并发特性。根据具体需求,你可以进一步探索和扩展这些示例。