go语言实现了协程,使得异步调用程序变得容易,而不用像线程一样考虑资源的申请释放。但是对于共享资源的访问,也需要通过加锁来保证数据的安全。虽然go语言不希望这么做,而是希望通过channel来实现将共享状态和共享状态的变化在各个协程间传递,这样同样能保证同一时间只有一个协程访问共享状态。
go提供了sync包,其中提供了等待组对象(sync.WaitGroup)、互斥锁(sync.Mutex)、读写锁(sync.RWMutex)等。
下面是关于互斥锁和等待组对象的使用实例:
package main
import (
"fmt"
"math/rand"
"sync"
"time"
)
//全局变量 景区门票
var ticket = 20
//创建同步等待组对象
var wg sync.WaitGroup
//创建互斥锁
var mutex sync.Mutex
func main() {
/*
wg.Add() 设置等待组中要执行的子协程的数量,相当于告诉主协程要等待的子协程数量
wg.Wait() 让主协程处于等待状态,处于阻塞状态
wg.Done() 子协程执行完调用,告诉主协程不用等自己了,
相当于 wg(-1),等待组中的计数减1,当值减到0,主协程退出等待状态
*/
wg.Add(3)
go saleTickets("售票口1")
go sal