> 백엔드 개발 > Golang > Go 언어가 높은 동시성을 지원하는 이유는 무엇일까요?

Go 언어가 높은 동시성을 지원하는 이유는 무엇일까요?

青灯夜游
풀어 주다: 2022-12-20 10:31:38
원래의
5851명이 탐색했습니다.

이유: Go 언어는 디자인 과정에서 키워드 수준에서 다중 코루틴 개발을 구현합니다. Go 언어는 동시성 기반으로 CSP 동시성 모델을 구현합니다. 하단 계층은 goroutine을 동시 엔터티로 사용합니다. Goroutine은 매우 가볍고 엔터티를 분리하기 위해 채널을 통해 수십만 개의 엔터티를 계속 생성할 수 있습니다. 언어 수준에서 구현됩니다. 많은 내부 세부 정보를 보호하고 외부 세계에 간단한 구문 키워드를 제공하는 자동 스케줄링이 구현되어 동시 프로그래밍의 사고 변환과 스레드 관리의 복잡성이 크게 단순화됩니다.

Go 언어가 높은 동시성을 지원하는 이유는 무엇일까요?

이 튜토리얼의 운영 환경: Windows 7 시스템, GO 버전 1.18, Dell G3 컴퓨터.

Go의 전설

Go에 대한 많은 전설이 있습니다. "자연스럽게 높은 동시성을 지원하고, 실행 속도는 C에 가깝고, 네트워크 서비스는 Nginx에 가깝습니다...". 다른 건 다 괜찮은데, 유일하게 이해하기 어려운 점은 "자연스럽게 높은 동시성을 지원한다"는 것인데, 특히 "자연스럽게"라는 단어는 정말 고급스럽고 신비로운 느낌을 줍니다.

먼저 Go에서 동시 작업을 구현하는 것이 얼마나 간단한지 살펴보겠습니다. 코드를 살펴보겠습니다.

func main()  {
   go add(3,6)  
   go add(1,6)  
   time.Sleep(time.Second)}func add(a int,b int)  {
   result := a+b
   fmt.Println(result)}
로그인 후 복사

go 키워드는 코루틴 열기 호출을 구현합니다. 기다리지 않으면 메인 스레드가 종료됩니다. 코루틴은 즉시 종료됩니다.

go의 동시성

실제로 go 언어의 goroutine은 참조(순차 프로세스 전달) 모델이며 원래 CSP의 채널에 있는 작업은 즉시 실행되며 go 언어는 캐시를 추가합니다. 즉, 작업을 임시로 저장한 다음 실행 프로세스가 준비될 때까지 순차적으로 하나씩 실행할 수 있습니다.

그러나 실제로 Go 언어는 CSP 모델의 모든 이론을 완전히 구현하지 않고 프로세스와 채널이라는 두 가지 개념만 차용합니다. Go 언어에서 프로세스의 성능은 고루틴이 실제로 동시에 실행되는 개체라는 점입니다. 채널 통신을 통해 각 개체 간에 데이터 공유가 이루어집니다.

1) Goroutine

Goroutine은 go의 실제 동시 실행 개체입니다. 그 하위 계층은 동시성을 달성하기 위해 코루틴을 사용하는 것입니다. 코루틴은 사용자 모드에서 실행되는 사용자 스레드입니다. 하단은 다음과 같은 특징을 갖기 때문입니다:

  1. 사용자 공간은 커널 모드와 사용자 모드 간 전환으로 인한 비용을 방지합니다.
  2. 언어 및 프레임워크 레이어에 의해 예약 가능
  3. 더 작은 스택 공간으로 대규모 생성이 가능합니다. 인스턴스 수

2) 채널

go는 CSP의 채널을 사용합니다. 채널은 별도로 생성되며 프로세스 간에 전달될 수 있습니다. 통신 모드는 상사-작업자 모드와 유사합니다. 엔터티는 채널에 메시지를 보낸 다음 두 엔터티 간의 관계를 수신합니다. 익명, 이는 채널이 동기식이며 메시지가 결국 다른 엔터티에 의해 소비되어야 합니다.

3) Scheduler

goroutine은 golang 수준의 스케줄러를 제공합니다. Goroutine은 비동기식으로 선점될 수 있으므로 함수 호출이 없는 루프는 더 이상 스케줄러에 교착 상태를 일으키지 않습니다. 수집 속도가 크게 느려집니다. 또한 Go는 네트워크 IO 라이브러리를 캡슐화하고 복잡한 세부 정보를 보호하며 외부 세계에 통합 구문 키워드 지원을 제공하고 동시 프로그램 작성 비용을 단순화합니다.

Summary

Golang은 동시성의 기초로 CSP 동시성 모델을 구현합니다. 고루틴은 동시 엔터티로 사용되며 수십만 개의 엔터티를 생성할 수 있습니다. 채널을 통한 엔터티 간의 지속적인 익명 메시징은 엔터티를 분리하고 언어 수준에서 자동 예약을 실현합니다. 이는 많은 내부 세부 정보를 보호하고 외부 세계에 간단한 구문 키워드를 제공하여 동시 프로그래밍의 사고 변환과 스레드 관리의 복잡성을 크게 단순화합니다. .

한 문장으로 요약: Go 언어는 마치 언어가 본질적으로 높은 동시성을 지원하는 것처럼 디자인 과정에서 키워드 수준에서 다중 코루틴 개발을 구현합니다.

【관련 추천: Go 비디오 튜토리얼, 프로그래밍 교육

위 내용은 Go 언어가 높은 동시성을 지원하는 이유는 무엇일까요?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
최신 이슈
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿