Go 协调goroutines

示例

想象一下一个具有两步过程的goroutine,其中主线程需要在每一步之间做一些工作:

func main() {
    ch := make(chan struct{})
    go func() {
        // 等待主线程的信号开始第一步
        <-ch
        
        // 执行工作
        time.Sleep(1 * time.Second)
        
        // 向主线程发出第一步已完成的信号
        ch <- struct{}{}
        
        // 等待主线程的信号开始第二步
        <-ch
        
        // 执行工作
        time.Sleep(1 * time.Second)
        
        // 向主线程发出工作已完成的信号
        ch <- struct{}{}
    }()
    
    // 通知goroutine第一步可以开始
    ch <- struct{}{}
    
    // 等待goroutine通知第一步已完成
    <-ch

    // 在通知之前执行一些工作
    // 第二步可以开始的程序
    time.Sleep(1 * time.Second)
    
    // 通知goroutine第二步可以开始
    ch <- struct{}{}
    
    // 等待goroutine通知第二步已完成
    <-ch
}