Go에서 버퍼링 잠금
Go에서는 버퍼드 채널을 사용하면 버퍼가 가득 찰 때까지 차단 없이 통신이 가능합니다. 이로 인해 질문이 제기됩니다. 제한된 수의 클라이언트에 대해 리소스가 잠기는 버퍼 잠금에 대한 일반적인 패턴이 있습니까?
답변: 세마포
제한된 수의 클라이언트에 대한 리소스를 잠그는 것은 세마포어입니다. 세마포어는 버퍼링된 채널을 사용하여 쉽게 구현됩니다.
다음 예를 고려하세요.
var semaphore = make(chan struct{}, 4) // allow four concurrent users func f() { // Grab the lock. Blocks as long as 4 other invocations of f are still running. semaphore <- struct{}{} // Release the lock once we're done. defer func() { <-semaphore }() // Do work... }
이 예에서는 4개의 요소(make(chan struct{}, 4)가 있는 버퍼링된 채널) )은 세마포어 역할을 합니다. f 함수는 채널에 값을 전송하여 잠금을 확보합니다. 채널이 가득 차면 값이 수신될 때까지 함수가 차단됩니다. 잠금이 획득되면 defer 문은 함수가 반환될 때 잠금이 해제되도록 보장합니다.
버퍼링된 채널로 구현된 세마포어를 사용하면 리소스에 대한 액세스를 제한된 수로 제한하는 버퍼링된 잠금 패턴을 생성할 수 있습니다. 동시 사용자 수
위 내용은 Go에서 버퍼링된 잠금을 구현하는 데 버퍼링된 채널을 사용할 수 있나요?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!