Go에서 변수에 대한 스레드 안전성을 구현하는 방법
Java에서 동기화된 변수의 개념은 단일 스레드만 실행할 수 있도록 보장합니다. 주어진 시간에 특정 코드 블록. 그러나 Go는 명시적인 동기화 키워드를 제공하지 않습니다.
이유
Go는 다음 원칙에 따라 스레드 동기화에 대한 다른 접근 방식을 권장합니다. 대신에 의사소통을 통해 기억을 공유하세요." 이는 공유 메모리에 대한 직접 액세스를 피하고 채널과 같은 통신 기반 메커니즘을 선택하는 것을 의미합니다.
뮤텍스 기반 동기화
뮤텍스가 필요한 시나리오가 발생해야 합니까? , 이를 구현하는 방법은 다음과 같습니다. 이동:
var ( mu sync.Mutex protectMe int ) func getMe() int { mu.Lock() me := protectMe mu.Unlock() return me } func setMe(me int) { mu.Lock() protectMe = me mu.Unlock() }
개선 사항
원자적 동기화
단일 값을 보호해야 하는 경우 sync/ 원자 패키지:
var protectMe int32 func getMe() int32 { return atomic.LoadInt32(&protectMe) } func setMe(me int32) { atomic.StoreInt32(&protectMe, me) }
통신 기반 접근법
Go는 공유 변수가 필요하지 않도록 고루틴 간 통신을 위한 채널 사용을 권장합니다. 예를 들어 게시자-구독자 패턴에서는 다음과 같습니다.
type topic struct { subscribing []chan int } var t = &topic{} func subscribe() chan int { ch := make(chan int) t.subscribing = append(t.subscribing, ch) return ch } func publish(v int) { for _, ch := range t.subscribing { ch <- v } }
이 접근 방식은 메모리 공유 없이 스레드로부터 안전한 통신을 보장합니다.
위 내용은 Go에서 스레드 안전성을 달성하는 방법: 뮤텍스, 원자성 또는 채널?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!