go 生产者消费者模型
package main
import (
"log"
"time"
)
func main() {
ch := make(chan int, 5)
startTime := time.Now().Unix()
log.Println("start")
go provide(ch)
time.Sleep(time.Second * 3)
for data := range ch {
if data == -1 {
log.Println("comsume is over. I'm so full")
break
} else {
log.Printf("comsume %d", data)
}
}
end := time.Now().Unix()
log.Println("end")
spend := end - startTime
log.Printf("spend %ds", spend)
}
func provide(ch chan int) {
for i := 0; i < 11; i++ {
ch <- i
log.Printf("provide %d", i)
}
ch <- -1
}
cook