golang并发编程_01

一、并发编程模板

func main() {
    ......
    var wg sync.WaitGroup

    wg.Add(1)
    go func() {
        defer wg.Done()
        // to do
    }()

    wg.Add(1)
    go func() {
        defer wg.Done()
        // todo
    }()

    wg.Wait()

}

二、锁住共享资源

1. 原子函数

var counter int64 //多个goroutine都会增加其值的变量

//如果在goroutine中要对counter执行加法,那么要用原子操作
atomic.AddInt64(&counter, 1) //对counter加1

另外两个有用的原子函数是 LoadInt64 和 StoreInt64.

2. 互斥锁

互斥锁用于在代码上创建一个临界区,保证同一时间只有一个 goroutine 可以执行这个临界区代码。

var (
    mutex sync.Mutex //定义一把互斥锁
    counter int      //多个goroutine要操作的变量
)


mutex.Lock()
{
    counter = 10

}
mutex.Unlock()

三、通道channel

当一个资源需要在 goroutine 之间共享时,通道在 goroutine 之间架起了一个管道,并提供了确保同步交换数据的机制。

1. 创建通道

//无缓冲的整形通道
unbufChan := make(chan int)

//有缓冲的字符串通道,通道大小是10个字符串
bufChan := make(chan string, 10)

2. 通道读写

bufChan := make(chan string, 10)
//向通道发送值
bufChan <- "hello"

//从通道取
value := <- bufChan

3. 无缓冲chan与有缓冲的区别

无缓冲chan是同步的,有缓冲chan是异步的。

 

你可能感兴趣的:(goLang)