在Golang中,進行并發編程主要依賴于兩個關鍵字:goroutine 和 channel。goroutine 是一種輕量級的線程,可以在程序中同時運行多個任務。channel 則用于在 goroutine 之間傳遞數據。
以下是一個簡單的示例,展示了如何在Linux中使用Golang進行并發編程:
package main
import (
"fmt"
"sync"
"time"
)
func printNumbers(wg *sync.WaitGroup) {
defer wg.Done() // 當函數執行完畢時,調用Done()通知WaitGroup
for i := 1; i <= 5; i++ {
fmt.Printf("Number: %d\n", i)
time.Sleep(1 * time.Second) // 暫停1秒
}
}
func main() {
var wg sync.WaitGroup // 創建一個WaitGroup實例
wg.Add(1) // 為WaitGroup添加一個任務
go printNumbers(&wg) // 啟動一個新的goroutine來執行printNumbers函數
wg.Wait() // 等待所有任務完成
fmt.Println("Finished")
}
在這個示例中,我們首先導入了 fmt、sync 和 time 包。然后定義了一個名為 printNumbers 的函數,該函數接受一個指向 sync.WaitGroup 的指針作為參數。在函數內部,我們使用 defer 關鍵字確保在函數執行完畢時調用 wg.Done()。
在 main 函數中,我們創建了一個 sync.WaitGroup 實例,并使用 wg.Add(1) 添加了一個任務。接著,我們使用 go 關鍵字啟動了一個新的 goroutine 來執行 printNumbers 函數。最后,我們使用 wg.Wait() 等待所有任務完成。
要運行此示例,請將代碼保存到一個名為 main.go 的文件中,然后在Linux終端中運行以下命令:
go run main.go
這將啟動一個新的 goroutine 來執行 printNumbers 函數,同時主線程會等待 goroutine 完成。