golang 함수와 goroutine 간의 상호 작용 메커니즘은 무엇입니까?

WBOY
풀어 주다: 2024-05-02 18:36:02
원래의
819명이 탐색했습니다.

함수와 고루틴은 Go 언어에서 다음 메커니즘을 통해 상호 작용합니다. 채널: 고루틴 간 데이터를 안전하게 교환합니다. 파이프: 외부 프로세스와 통신하는 데 사용됩니다.

golang 함수와 goroutine 간의 상호 작용 메커니즘은 무엇입니까?

Go 언어의 함수는 고루틴 메커니즘과 상호 작용합니다.

고루틴 소개

고루틴 Go 프로그램이 코드를 병렬로 실행할 수 있게 해주는 경량 스레드입니다. Go 런타임에 의해 관리되며 스레드를 수동으로 생성하고 관리할 필요 없이 병렬로 작업을 처리하는 데 사용됩니다.

함수와 고루틴 간의 상호 작용

Go 언어에서 함수와 고루틴 간의 상호 작용은 다음 메커니즘을 통해 이루어집니다.

  • 채널(Channel):고루틴 간에 데이터를 안전하게 교환하기 위한 통신 메커니즘입니다. 송신자가 채널에 데이터를 쓰고 수신자가 채널에서 데이터를 읽는 형식화된 대기열입니다.
  • 파이프:명령줄 도구나 기타 외부 프로세스와 통신하도록 설계된 특별한 유형의 채널입니다.

실용 사례: 병렬 합산

함수와 고루틴 간의 상호 작용을 보여주기 위해 간단한 병렬 합산 프로그램을 만듭니다:

package main import ( "fmt" "math/rand" "sync" "time" ) const numIterations = 1000000 func main() { sum := 0 // 初始化互斥锁以保护并发的 sum 变量 lock := &sync.Mutex{} // 创建一个通道 c := make(chan int) // 创建 Goroutine 并发计算和并将结果发送到通道 for i := 0; i < numIterations; i++ { go func(num int) { rand.Seed(time.Now().UnixNano()) time.Sleep(time.Duration(rand.Intn(50)) * time.Millisecond) lock.Lock() defer lock.Unlock() sum += num c <- num }(i) } // 从通道接收数据并打印进度条 for i := 0; i < numIterations; i++ { <-c fmt.Printf("\rProgress: %f%", float64(i)/float64(numIterations)*100) } // 等待所有 Goroutine 完成 time.Sleep(time.Second) fmt.Println("\nFinal sum:", sum) }
로그인 후 복사

이 프로그램에서는 파이프와 뮤텍스 잠금을 사용하여 함수와 고루틴 간의 연결을 구현합니다. 상호 작용:

  • 뮤텍스는 동시에 액세스되는 변수sum를 보호하여 데이터 무결성을 보장합니다.
  • 고루틴은 합산 결과를 파이프라인으로 보냅니다.
  • 주 함수는 파이프에서 결과를 읽고 진행률 표시줄을 인쇄합니다.

이 메커니즘을 통해 고루틴은 합산 작업을 동시에 실행할 수 있으며, 주요 기능은 진행 상황을 추적하고 최종 결과를 수집할 수 있습니다.

위 내용은 golang 함수와 goroutine 간의 상호 작용 메커니즘은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

관련 라벨:
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿
회사 소개 부인 성명 Sitemap
PHP 중국어 웹사이트:공공복지 온라인 PHP 교육,PHP 학습자의 빠른 성장을 도와주세요!