golang并发安全和锁
互斥锁:
package main
import (
"fmt"
"sync"
)
var (
x int64
wg sync.WaitGroup
lock sync.Mutex
)
func add() {
for i := 0; i < 5000000; i++ {
lock.Lock() // 加锁
x = x + 1
lock.Unlock() // 解锁
}
wg.Done()
}
func main() {
wg.Add(2)
go add()
go add()
wg.Wait()
fmt.Println(x)
}
读写锁:
适用于读多写少的场景:
package main
import (
"fmt"
"sync"
"time"
)
var (
x int64
wg sync.WaitGroup
lock sync.Mutex
rwLock sync.RWMutex
)
func read() {
//lock.Lock()
rwLock.Lock()
time.Sleep(time.Millisecond)
rwLock.Unlock()
//lock.Unlock()
wg.Done()
}
func write() {
//lock.Lock()
rwLock.Lock()
x++
time.Sleep(time.Millisecond * 10)
rwLock.Unlock()
//lock.Unlock()
wg.Done()
}
func main() {
start := time.Now()
for i := 0; i < 1000; i++ {
wg.Add(1)
go read()
}
for i := 0; i < 10; i++ {
wg.Add(1)
go write()
}
wg.Wait()
fmt.Println(time.Now().Sub(start))
fmt.Println(x)
}