温馨提示×

Debian下Golang如何实现并发控制

小樊
43
2025-11-15 10:49:21
栏目: 编程语言

在Golang中,实现并发控制的主要方法是使用goroutines和channels。goroutines是轻量级的线程,可以在程序中同时运行多个任务。channels则用于在goroutines之间传递数据和同步操作。

以下是一个简单的示例,展示了如何在Debian下的Golang程序中使用goroutines和channels实现并发控制:

package main

import (
	"fmt"
	"sync"
	"time"
)

func worker(id int, wg *sync.WaitGroup, ch chan<- string) {
	defer wg.Done()

	// 模拟任务执行时间
	time.Sleep(time.Second)

	// 向channel发送消息
	ch <- fmt.Sprintf("Worker %d completed", id)
}

func main() {
	// 设置并发任务数量
	numTasks := 5

	// 创建一个WaitGroup,用于等待所有goroutines完成
	var wg sync.WaitGroup
	wg.Add(numTasks)

	// 创建一个channel,用于接收goroutines发送的消息
	ch := make(chan string, numTasks)

	// 启动多个goroutines执行任务
	for i := 1; i <= numTasks; i++ {
		go worker(i, &wg, ch)
	}

	// 等待所有goroutines完成
	wg.Wait()

	// 关闭channel
	close(ch)

	// 从channel接收并打印消息
	for msg := range ch {
		fmt.Println(msg)
	}
}

在这个示例中,我们创建了5个goroutines来执行任务。每个任务完成后,它会向channel发送一条消息。主函数使用sync.WaitGroup来等待所有goroutines完成,然后关闭channel并打印所有消息。

这个示例展示了如何在Debian下的Golang程序中使用goroutines和channels实现并发控制。你可以根据自己的需求调整任务数量和任务执行时间。

0