Golang 原子锁是一种用于同步访问共享资源的机制。原子锁可以确保在同一时刻只有一个线程可以访问共享资源,从而避免并发访问导致的数据竞争问题。
在 Golang 中,原子锁可以通过标准库中的 sync 包提供的两个类型来实现:Mutex 和 RWMutex。其中 Mutex 是一种基本的互斥锁,只能被一个 goroutine 持有,其他 goroutine 需要等待锁释放后才能访问共享资源。而 RWMutex 则支持读写分离,多个 goroutine 可以同时读取共享资源,但是只有一个 goroutine 能够进行写操作。
使用 Mutex 实现原子锁的代码示例:
import "sync"
var mu sync.Mutex // 定义一个互斥锁
func main() {
mu.Lock() // 获取锁
defer mu.Unlock() // 在函数退出时释放锁
// 访问共享资源
}
使用 RWMutex 实现原子锁的代码示例:
import "sync"
var rwmu sync.RWMutex // 定义一个读写锁
func main() {
rwmu.RLock() // 获取读锁
defer rwmu.RUnlock() // 在函数退出时释放读锁
// 访问共享资源(只读)
rwmu.Lock() // 获取写锁
defer rwmu.Unlock() // 在函数退出时释放写锁
// 访问共享资源(读写)
}
除了 Mutex 和 RWMutex 之外,Golang 还提供了一些原子操作的函数,如 atomic.AddInt32()、atomic.LoadUint64() 等,可以在不使用锁的情况下实现对共享资源的原子访问。这些函数的底层实现通常会利用硬件原语(如 CPU 指令)来保证原子性。