は、同時コア ユニットが通信用のデータを送受信できるパイプと考えることができます。この記事では、channel について詳しく説明します。 チャネルの作成
を使用します。
aChan := make(chan int) // 创建无缓冲chan bChan := make(chan int, N) // 创建缓冲为N的chan
。 mchan <- value // 发送值v到Channel ch中
value := <-mchan // 从Channel ch中接收数据,并将数据赋值给v
Select
は、チャネルでデータを取得する最も一般的な方法です。 select 一定程度上可以类比于 linux 中的 IO 多路复用中的 select。后者相当于提供了对多个 IO 事件的统一管理,而 Golang 中的 select 相当于提供了对多个 channel 的统一管理。当然这只是 select 在 channel 上的一种使用方法。 for …… range语句可以处理Channel。 Select很重要的一个应用就是超时处理。因为上面提供的demo,select语句就会一直阻塞着。这时候我们可能就需要一个超时操作,用来处理超时的情况。下面这个例子我们会在2秒后往channel c1中发送一个数据,但是Select设置为1秒超时,因此我们会打印出timeout 1,而不是result 1。 Go内建的close方法就可以用来关闭channel。但如果channel 已经被关闭,继续往它发送数据会导致panic: send on closed channel: close(mChan)func main(){
ch1 := make(chan int, 1)
ch2 := make(chan int, 1)
select {
case e1 := <-ch1:
//如果ch1通道成功读取数据,则执行该case处理语句
fmt.Printf("1th case is selected. e1=%v",e1)
case e2 := <-ch2:
//如果ch2通道成功读取数据,则执行该case处理语句
fmt.Printf("2th case is selected. e2=%v",e2)
default:
//如果上面case都没有成功,则进入default处理流程
fmt.Println("default!.")
}
}
for…range
go func() {
time.Sleep(1 * time.Hour)
}()
c := make(chan int)
go func() {
for i := 0; i < 10; i = i + 1 {
c <- i
}
close(c)
}()
for i := range c {
fmt.Println(i)
}
fmt.Println("Finished")
timeout
c1 := make(chan string, 1)
go func() {
time.Sleep(time.Second * 2)
c1 <- "result 1"
}()
select {
case res := <-c1:
fmt.Println(res)
case <-time.After(time.Second * 1):
fmt.Println("timeout 1")
}
close
以上がGo の同時実行性は、ネットワークのない iPhone のようなものですの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。