golang 通道同步功能

/*
    go通道的同步功能
    我们使用通道来同步协程之间的执行
    下面的例子是通过获取同步通道数据
    来阻塞程序执行的方法来等待另一个协程运行结束的
    也就是说main函数所在的协程在运行到《-done
    语句的时候等待woker
    函数所在的协程执行完成
    向通道写入数据后才会继续执行
*/

package main

import (
    "fmt"
    "time"
)

//这个worker函数将以协程的方式运行
/*
  通道done被用来通知另外一个协程这个worker函数已经执行完成
*/

func worker(done chan bool) {
    fmt.Print("working....")
    time.Sleep(time.Second)
    fmt.Println("done")

    //向通道发送一个数据 表示worker函数已经执行完成
    done <- true
}

func main() {
    /*
        使用协程来调用worker函数 同时将通道‘done’传递给协程
        是的协程可以通知别的协程自己已经执行完成
    */

    done := make(chan bool, 1)
    go worker(done)

    //一直阻塞 直到从woker所在协程获得一个worker执行完成的数据
    <-done
    //假如我们从main函数里面移除 <-done语句 那么main函数在worker
    //协程开始运行之前就结束了
}
 

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值