ok pattern 测试,
func main() {
c := make(chan []int)
a := []int{1, 2, 3, 4}
go func() {
c <- a
close(c)
}()
for i := 1; i <= 3; i++ {
t, ok := <-c
fmt.Println(i, ":", t, ok)
}
}
/*输出:
1 : [1 2 3 4] true
2 : [] false
3 : [] false
*/
func main() {
c := make(chan []int, 1)
a := []int{1, 2, 3, 4}
go func() {
c <- a
close(c)
}()
for i := 1; i <= 3; i++ {
t, ok := <-c
fmt.Println(i, ":", t, ok)
}
}
/*输出:
1 : [1 2 3 4] true
2 : [] false
3 : [] false
*/
func main() {
c := make(chan []int, 1)
a := []int{1, 2, 3, 4}
go func() {
c <- a
}()
time.Sleep(2 * time.Second)
close(c)
for i := 1; i <= 3; i++ {
t, ok := <-c
fmt.Println(i, ":", t, ok)
}
}
/*输出:
1 : [1 2 3 4] true
2 : [] false
3 : [] false
*/
func main() {
c := make(chan []int)
a := []int{1, 2, 3, 4}
go func() {
c <- a
}()
time.Sleep(2 * time.Second)
close(c)
for i := 1; i <= 3; i++ {
t, ok := <-c
fmt.Println(i, ":", t, ok)
}
}
/*输出:
panic: send on closed channel
goroutine 18 [running]:
main.main.func1(0xc00009c000, 0xc00009e000, 0x4, 0x4)
/Users/xxx/temp/gotest/gotest.go:30 +0x53
created by main.main
/Users/xxx/temp/gotest/gotest.go:29 +0xb5
exit status 2
*/
结论:
1.不要在channel的接收端关闭channel,如果channel不带缓存,即使先执行发送数据的动作,也会导致panic。
2. 在channel的发送端关闭channel,关闭后channel中的数据可以用OK pattern读取到