概述
Go语言中,协程可以简单理解为轻量级的线程。
协程开销比线程低,M个协程运行在N个线程上,也就是通常所说的M:N模型。协程完全由Golang运行时管理,而不是由操作系统管理。线程是抢占式的多任务,而协程是非抢占式的任务。通过以上这些方法,从而实现了协程的轻量化。
使用
Golang创建协程非常简单,只需要go FuncName()
即可。
package main
import (
"fmt"
)
func print(name string) {
for i := 0; i < 5; i++ {
fmt.Printf("%s: %d\n", name, i)
}
}
func main() {
go print("go")
print("main")
}
输出:
main: 0
main: 1
main: 2
main: 3
main: 4
可以看到,只在主协程有输出,这是因为主协程不会等待其他协程执行完成。这里,我们可以加上一个等待时间,就可以看到其他协程的执行。
修改后的代码:
import (
"fmt"
"time"
)
func print(name string) {
for i := 0; i < 5; i++ {
time.Sleep(5 * time.Millisecond)
fmt.Printf("%s: %d\n", name, i)
}
}
func main() {
go print("go")
print("main")
}
输出:
main: 0
go: 0
go: 1
main: 1
main: 2
go: 2
go: 3
main: 3
main: 4
go: 4
Go语言支持匿名函数,那当然也就支持匿名协程了。
这里也加上了sleep函数,否则主线程就不会等待协程就直接结束了。
package main
import (
"fmt"
"time"
)
func main() {
go func(name string) {
for i := 0; i < 5; i++ {
fmt.Printf("%s: %d\n", name, i)
}
}("go")
time.Sleep(10 * time.Millisecond)
}
输出:
go: 0
go: 1
go: 2
go: 3
go: 4