在Go语言中,保证并发编程的线程安全主要依赖于以下几个方面:
sync.Mutex
结构体来实现互斥锁。import "sync"
var mu sync.Mutex
var counter int
func increment() {
mu.Lock()
defer mu.Unlock()
counter++
}
sync.RWMutex
结构体来实现读写锁。import "sync"
var rwMu sync.RWMutex
var sharedData map[string]string
func readData(key string) string {
rwMu.RLock()
defer rwMu.RUnlock()
return sharedData[key]
}
func writeData(key, value string) {
rwMu.Lock()
defer rwMu.Unlock()
sharedData[key] = value
}
sync/atomic
包来实现原子操作。import "sync/atomic"
var counter int64
func increment() {
atomic.AddInt64(&counter, 1)
}
func worker(done chan bool) {
// Do some work...
done <- true
}
func main() {
done := make(chan bool)
go worker(done)
<-done
}
sync
包还提供了许多其他的同步原语,如sync.WaitGroup
、sync.Once
等,可以用于实现更复杂的并发控制。总之,在Go语言中,保证并发编程的线程安全需要使用适当的同步原语来确保对共享资源的访问是互斥或有序的。在实际编程中,应根据具体场景选择合适的同步机制。