golang注意Channel的阻塞特性
2014-02-13 11:12
399 查看
本博客已迁移至 www.0x520.com
之前用channel练习的时候遇到一个问题,看似好像代码合理,而且编译也不会有问题,但忘记了一个重要的channel特性。正确的代码:
package main import "fmt" func foo(){ defer fmt.Println("World") fmt.Println("Hello") } func sum(x,y int,c chan int){ c <- x + y } func main(){ foo() c := make (chan int); go sum(24,18,c) fmt.Println(<-c); }
如果我把代码改成:
package main import "fmt" func foo(){ defer fmt.Println("World") fmt.Println("Hello") } //func sum(x,y int,c chan int){ // c <- x + y //} func main(){ foo() // c := make (chan int); // go sum(24,18,c) // fmt.Println(<-c); c := make (chan int) d := 2 c <- d+3 fmt.Println(<-c) }
或者
package main import "fmt" func foo(){ defer fmt.Println("World") fmt.Println("Hello") } func sum(x,y int,c chan int){ c <- x + y } func main(){ foo() c := make (chan int); sum(24,18,c) fmt.Println(<-c); }
都会出现以下错误:
Hello World fatal error: all goroutines are asleep - deadlock! goroutine 1 [chan send]: main.main() /Users/john/a1.go:20 +0x60 exit status 2
这是为什么呢,看似合理的程序,是忽略了Channel是阻塞的,如果没有使用go Channel就一直在阻塞的状态,执行就死循环了。这个特性也在很多场合带来了方便。
相关文章推荐
- golang协程 通道channel阻塞
- golang协程——通道channel阻塞
- golang channel阻塞问题解决
- Golang channel 特性
- Golang -- 使用 Bufferd channel 实现 线程安全的 pool
- 【系列】重新认识Java——泛型(通配、特性和注意点)
- golang mutex使用及注意事项
- [转]Go的50坑:新Golang开发者要注意的陷阱、技巧和常见错误-高级
- golang的Channel
- Golang channel和select配合使用
- Golang channel 的实现原理
- golang channel 的使用
- Android N 新特性 + APP开发注意事项
- Golang 特性简介
- Linux下Socket通信中非阻塞connect的注意事项
- golang将多路复异步io转成阻塞io的方法详解
- golang语言并发与并行——goroutine和channel的详细理解(三)
- 非阻塞socket与epoll的ET模式结合使用注意事项
- (转)非阻塞Connect对于select时应注意问题
- Golang Channel用法简编