1.Mutex互斥锁
package cmd
import (
"fmt"
"sync"
)
var count int
var mtx sync.Mutex
var wg sync.WaitGroup
func add() {
mtx.Lock()
defer mtx.Unlock()
defer wg.Done()
count += 1
}
func main() {
for i := 0; i < 1000; i++ {
wg.Add(1)
go add()
}
wg.Wait()
fmt.Println("count :", count)
}
2.chan互斥锁
package cmd
import (
"fmt"
"sync"
)
var count int
func add(h chan int, wg *sync.WaitGroup) {
defer wg.Done()
h <- 1
count += 1
<-h
}
func main() {
ch := make(chan int, 1)
wg := &sync.WaitGroup{}
for i := 0; i < 1000; i++ {
wg.Add(1)
go add(ch, wg)
}
wg.Wait()
fmt.Println("count :", count)
}
本文探讨了两种在Go语言中实现互斥锁的方法:使用Mutex和使用Chan。通过示例代码展示了如何在多线程环境下保证变量count的安全增加,确保并发安全。在Mutex示例中,通过Lock和Unlock实现同步;而在Chan示例中,通过传递信号实现资源的互斥访问。最终,两个示例都成功地在1000次并发操作后输出正确的count值。
1968

被折叠的 条评论
为什么被折叠?



