golang sync.RWMutex

sync.RWMutex
package main

import (
    "fmt"
    "runtime"
    "sync"
)

func clickWithMutex(total *int, m *sync.RWMutex, ch chan int) {
    for i := 0; i < 1000; i++ {
        m.Lock()
        *total += 1
        m.Unlock()
        //这里是写 下面是读,外层还有线程的竞争
        if i == 500 {
            m.RLock()
            fmt.Println(*total)
            m.RUnlock()
        }
    }
    ch <- 1
}

func main() {

    runtime.GOMAXPROCS(4) //使用多个处理器,不然都是顺序执行。

    m := new(sync.RWMutex)
    count := 0

    ch := make(chan int, 10) //保证输出时count完了

    for i := 0; i < 10; i++ {
        go clickWithMutex(&count, m, ch)
    }

    for i := 0; i < 10; i++ {
        <-ch
    }

    fmt.Printf("count:%d\n", count)
}

 

本文来自:博客园

感谢作者:rojas

查看原文:golang sync.RWMutex

郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。