Golang 표준 라이브러리의 동시 프로그래밍 가이드
소개:
동시 프로그래밍은 프로그램 성능 문제를 해결하고 컴퓨팅 리소스를 효율적으로 사용하는 중요한 수단입니다. Golang 프로그래밍 언어에서는 다양한 동시 프로그래밍 도구와 방법이 제공됩니다. 이 기사에서는 Golang 표준 라이브러리의 몇 가지 일반적인 동시 프로그래밍 기술을 소개하고 특정 코드 예제를 통해 사용법과 예방 조치를 설명합니다.
package main import ( "fmt" "time" ) func printNumbers() { for i := 0; i < 5; i++ { fmt.Printf("%d ", i) time.Sleep(time.Millisecond * 500) } } func printLetters() { for i := 'A'; i < 'F'; i++ { fmt.Printf("%c ", i) time.Sleep(time.Millisecond * 500) } } func main() { go printNumbers() // 启动一个Goroutine,打印数字 go printLetters() // 启动另一个Goroutine,打印字母 time.Sleep(time.Second * 3) // 等待两个Goroutine执行完毕 fmt.Println("Done") }
위 코드에서 우리는 각각 printNumbers
와 printLetters
두 함수를 정의하고 go
를 전달했습니다. code> 키워드는 각각 두 개의 고루틴으로 시작합니다. time.Sleep
함수를 사용하여 두 고루틴의 실행이 완료될 때까지 기다리면 출력 결과에 숫자와 문자가 번갈아 출력되는 것을 볼 수 있습니다. printNumbers
和printLetters
两个函数,并通过go
关键字将它们分别启动为两个Goroutine。通过time.Sleep
函数等待两个Goroutine执行完毕,可以看到输出结果中数字和字母是交替输出的。
package main import ( "fmt" "time" ) func worker(id int, jobs <-chan int, results chan<- int) { for job := range jobs { fmt.Printf("Worker %d started job %d ", id, job) time.Sleep(time.Second) fmt.Printf("Worker %d finished job %d ", id, job) results <- job * 2 } } func main() { numJobs := 5 jobs := make(chan int, numJobs) results := make(chan int, numJobs) numWorkers := 3 for w := 1; w <= numWorkers; w++ { go worker(w, jobs, results) } for j := 1; j <= numJobs; j++ { jobs <- j } close(jobs) for a := 1; a <= numJobs; a++ { result := <-results fmt.Println("Result:", result) } }
在上述代码中,我们定义了worker
函数,该函数用于接收jobs通道传入的数字,并进行相应的处理,结果通过results通道返回。在主函数中,我们分别创建了jobs和results两个通道,并将jobs通道传递给三个Goroutine执行。然后,通过for循环向jobs通道发送5个作业,并关闭通道。最后,通过for循环接收results通道的返回结果并输出。
sync
包提供了WaitGroup类型来实现这个功能。下面是一个使用WaitGroup的示例:package main import ( "fmt" "sync" "time" ) func worker(id int, wg *sync.WaitGroup) { defer wg.Done() fmt.Printf("Worker %d starting ", id) time.Sleep(time.Second) fmt.Printf("Worker %d done ", id) } func main() { var wg sync.WaitGroup numWorkers := 3 wg.Add(numWorkers) for w := 1; w <= numWorkers; w++ { go worker(w, &wg) } wg.Wait() fmt.Println("All workers done") }
在上述代码中,我们定义了worker
函数,该函数接收一个WaitGroup参数,执行相应的任务,并在任务执行完成后通过Done
方法通知WaitGroup。在主函数中,我们创建了一个WaitGroup变量,并通过Add
方法指定需要等待的Goroutine数量。然后,使用go
关键字启动相应数量的Goroutine,并将WaitGroup指针传递给每个Goroutine。最后,通过Wait
Golang에서는 고루틴간의 통신은 Channel을 통해 완성됩니다. 채널은 고루틴 간에 데이터를 전달하는 데 사용되는 유형 안전 대기열입니다. 다음은 간단한 채널 예입니다.
worker
함수를 정의합니다. 전달된 결과 채널이 반환됩니다. 기본 함수에서는 작업과 결과라는 두 개의 채널을 각각 생성하고 실행을 위해 작업 채널을 세 개의 고루틴에 전달했습니다. 그런 다음 for 루프를 통해 5개의 작업을 작업 채널로 보내고 채널을 닫습니다. 마지막으로 결과 채널의 반환 결과는 for 루프를 통해 수신되어 출력됩니다. 🎜sync
패키지는 이 기능을 구현하기 위해 WaitGroup 유형을 제공합니다. 다음은 WaitGroup 사용 예입니다. 🎜🎜rrreee🎜위 코드에서는 WaitGroup 매개변수를 전달받아 해당 작업을 실행하고 Doneworker 함수를 정의했습니다. /code> 메소드는 WaitGroup에 알립니다. 메인 함수에서는 WaitGroup 변수를 생성하고 Add
메소드를 통해 대기할 고루틴 수를 지정합니다. 그런 다음 go
키워드를 사용하여 해당하는 수의 고루틴을 시작하고 WaitGroup 포인터를 각 고루틴에 전달합니다. 마지막으로 Wait
메소드를 통해 모든 고루틴 실행이 완료될 때까지 기다립니다. 🎜🎜요약: 🎜Golang 표준 라이브러리에서 제공하는 동시 프로그래밍 도구와 방법을 통해 동시성이 높은 프로그램을 쉽게 구현할 수 있습니다. 이 기사에서는 Goroutine, Channel 및 WaitGroup과 같은 일반적인 동시 프로그래밍 기술을 소개하고 특정 코드 예제를 통해 설명합니다. 이 글을 통해 독자들이 Golang의 동시 프로그래밍 기술을 더 잘 익히고 프로그램의 성능과 운영 효율성을 향상시킬 수 있기를 바랍니다. 🎜위 내용은 동시 프로그래밍 가이드: Golang 표준 라이브러리의 병렬성 탐색의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!