协程创建
使用 go 关键字创建 goroutine 时,被调用函数的返回值会被忽略。如果需要在 goroutine 中返回数据,需要通道(channel)把数据从 goroutine中作为返回值传出
go 函数名( 参数列表 )
优点:
-
开销小
每个协程goroutine 默认占用的内存仅2Kb(线程8Mb),远比java和c少 -
调度性能好
golang可以控制协程goroutine的调度,使得在一个合适的时间进行GC
通道(channel)
一个 channels 是一个通信机制,它可以让一个 goroutine 通过它给另一个 goroutine 发送值信息。每个 channel 都有一个特殊的类型,也就是 channels 可发送数据的类型。
创建通道
ch1 := make(chan int) // 创建一个整型类型的通道
ch2 := make(chan interface{}) // 创建一个空接口类型的通道, 可以存放任意格式
type data struct{ /* 一些字段 */ }
ch2 := make(chan *data) // 创建Equip指针类型的通道, 可以存放*data
示例代码
func main() {
// 构建一个通道
ch := make(chan int)
// 开启一个并发匿名函数
go func() {
// 从3循环到0
for i := 3; i >= 0; i-- {
// 发送3到0之间的数值
ch <- i
// 每次发送完时等待
time.Sleep(time.Second)
}
}()
// 遍历接收通道数据
for data := range ch {
// 打印通道数据
fmt.Println(data)
// 当遇到数据0时, 退出接收循环
if data == 0 {
break
}
}
}