锁与通道在实现互斥锁功能的性能开销比对

yandi · · 1121 次点击 · · 开始浏览    
这是一个创建于 的文章,其中的信息可能已经有所发展或是发生改变。

### 测试使用的操作系统及内核版本 ```shell $ uname -a Linux CentOS 3.10.0-1127.8.2.el7.x86_64 #1 SMP Tue May 12 16:57:42 UTC 2020 x86_64 x86_64 x86_64 GNU/Linux ``` ### 使用sync.Mutex实现锁机制代码 ```go package main import "sync" func main() { num, wg, mux := new(int), new(sync.WaitGroup), new(sync.Mutex) wg.Add(2) go func(num *int, wg *sync.WaitGroup, mux *sync.Mutex) { defer wg.Done() for i := 1; i <= 100000000; i++ { mux.Lock() *num++ mux.Unlock() } }(num, wg, mux) go func(num *int, wg *sync.WaitGroup, mux *sync.Mutex) { defer wg.Done() for i := 1; i <= 100000000; i++ { mux.Lock() *num-- mux.Unlock() } }(num, wg, mux) wg.Wait() println(*num) } ``` ### 操作系统执行时间 ```shell $ time ./test-mutex 0 real 0m8.638s user 0m16.980s sys 0m0.012s ``` ### 使用chan bool实现锁机制代码 ```go package main import "sync" func main() { num, wg, mux := new(int), new(sync.WaitGroup), make(chan bool, 1) defer close(mux) wg.Add(2) go func(num *int, wg *sync.WaitGroup, mux chan bool) { defer wg.Done() for i := 1; i <= 100000000; i++ { mux <- true *num++ <-mux } }(num, wg, mux) go func(num *int, wg *sync.WaitGroup, mux chan bool) { defer wg.Done() for i := 1; i <= 100000000; i++ { mux <- true *num-- <-mux } }(num, wg, mux) wg.Wait() println(*num) } ``` ### 操作系统执行时间 ```shell $ time ./test-chan 0 real 0m44.766s user 0m48.069s sys 0m1.276s ``` 在golang中实现锁机制可以完全不需要考虑通道了,因为性能开销实在不是一个数量级

有疑问加站长微信联系(非本文作者))

入群交流(和以上内容无关):加入Go大咖交流群,或添加微信:liuxiaoyan-s 备注:入群;或加QQ群:692541889

1121 次点击  ∙  1 赞  
加入收藏 微博
4 回复  |  直到 2020-05-31 21:30:35
暂无回复
添加一条新回复 (您需要 登录 后才能回复 没有账号 ?)
  • 请尽量让自己的回复能够对别人有帮助
  • 支持 Markdown 格式, **粗体**、~~删除线~~、`单行代码`
  • 支持 @ 本站用户;支持表情(输入 : 提示),见 Emoji cheat sheet
  • 图片支持拖拽、截图粘贴等方式上传