首页 > 其他 > 详细

golang sync.RWMutex

时间:2015-04-09 10:27:27      阅读:194      评论:0      收藏:0      [点我收藏+]
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)
}

 

golang sync.RWMutex

原文:http://www.cnblogs.com/rojas/p/4408707.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!