Go语言是一种开源的编程语言,其中使用了并发编程模型来处理多个任务之间的交替执行。在并发编程中,往往涉及到多个协程或线程同时访问共享资源的情况,此时就需要使用互斥锁来保证资源的独占性,避免竞态条件的发生。
在Go语言中,提供了sync
包来实现各种同步原语,其中就包括互斥锁。sync.Mutex
类型是最基本的互斥锁类型,它通过两个方法Lock
和Unlock
来实现资源的互斥访问。
下面我们来具体看一下sync.Mutex
的使用。
package main
import (
"fmt"
"sync"
"time"
)
var count int
var mutex sync.Mutex
func increment() {
mutex.Lock() // 加锁
defer mutex.Unlock() // 解锁,在函数执行完毕后自动调用
count++
}
func main() {
for i := 0; i < 10; i++ {
go increment()
}
time.Sleep(time.Second) // 等待所有协程执行完毕
fmt.Println("count:", count)
}
在上面的代码中,首先定义了一个全局变量count
用来记录计数器的值,然后定义了一个sync.Mutex
类型的互斥锁mutex
。在increment
函数中,通过调用mutex.Lock()
来获得互斥锁,保证只有一个协程能够进入临界区执行count++
操作,然后调用mutex.Unlock()
来释放互斥锁,让其他协程可以继续竞争执行。
在main
函数中,通过循环创建了10个协程,每个协程都调用increment
函数来增加计数器的值。为了保证所有协程都执行完毕,我们使用time.Sleep
函数来让主协程等待1秒钟。
最后,我们将计数器的值打印出来,可以看到正确输出了count: 10
。
使用互斥锁可以保证共享资源的安全访问,避免了数据竞态的发生。在多个协程或线程访问共享资源时,使用互斥锁是非常重要的。Go语言的sync.Mutex
提供了简单而强大的互斥锁功能,使得并发编程变得更加容易和安全。