go by example之channel-synchronization.go

本文通过一个简单的Go语言程序示例介绍了如何使用Go语言进行并发编程。示例中创建了一个worker协程,该协程执行一些任务并在完成后通知主线程。文章展示了如何使用channel来同步协程,并解释了如何在等待并发任务完成的同时执行其他操作。
// 这个程序的例子说明,GO语言的并发是多么简洁,就是一个通用的结构,稍微改造后就可以用于实际中
// 对这个例子做了一些修改和说明
package main

import "fmt"
import "time"

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

    done <- true
}

func main() {

    done := make(chan bool, 1)
    fmt.Println("working A....")
    go worker(done)

    //模拟做其它的事
    //下面这句话是自己增加的, 原代码中没有
    fmt.Println("working B....")

    //等待并发的结束,如果没有结束,就阻塞在这里
    <-done
    fmt.Println("all work finish!")
}

执行结果:
working A….
working B….
working…done
all work finish!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值