首页 > 其他 > 详细

go16---select

时间:2017-12-21 23:32:40      阅读:211      评论:0      收藏:0      [点我收藏+]
package main

/*
Channel

Channel 是 goroutine 沟通的桥梁, goroutine是通过通信来进行内存的共享,
而不是通过内存的共享来进行通信,通过Channel通道来共享内存,
通过通道的通信(写进去在读出来)进行数据的传递,大都是阻塞同步的
通过 make 创建,close 关闭
Channel 是引用类型
可以使用 for range 来迭代不断操作 channel
可以设置单向(只读或者只写)或双向通道(读写)
可以设置缓存大小,不设置就是0是阻塞的,在未被填满前不会发生阻塞,
有缓存是异步的无缓存是同步的,

Select

可处理一个或多个 channel 的发送与接收
同时有多个可用的 channel时按随机顺序处理
可用空的 select 来阻塞 main 函数
*/
import (
    "fmt"
)

func main1() {
    c := make(chan int)
    go func() { //不断从c读值
        for v := range c {
            fmt.Println(v)
        }
    }()

    for {
        select { //随机向c中写0或者1
        case c <- 0:
        case c <- 1:
        }
    }

}

func main() {
    c := make(chan int)
    go func() { //不断从c读值
        for v := range c {
            fmt.Println(v)
        }
    }()

    for {
        select {} //空的select,没有发送和接收,完全阻塞main函数,
    }

}

/*
    c1: 1
    c2: c2
    c1: 3
    c2: c22
*/

 

go16---select

原文:http://www.cnblogs.com/yaowen/p/8082901.html

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