golang协程介绍和理解

1、介绍协程前先需要了解进程和线程

进程:程序在操作系统中的一次执行过程,系统进行资源分配和调度的一个独立单位。
线程:进程的一个执行实体,是CPU调度和分派的基本单位,它是比进程更小的能独立运行的基本单位。
进程和线程的关系:一个进程可以创建和撤销多个线程;同一个进程中的多个线程之间可以并发执行。

2、介绍协程

协程:独立的栈空间,共享堆空间,调度由用户自己控制,本质上有点类似于用户级线程,这些用户级线程的调度也是自己实现的。
线程和协程的关系:一个线程上可以跑多个协程,协程是轻量级的线程。

3、介绍goroutine

本质上,goroutine就是协程。不同的是,Golang在runtime、系统调用等多方面对goroutine调度进行了封装和处理。
Go语言编程中你不需要去自己写进程、线程、协程,你的技能包里只有一个技能goroutine。当你需要让某个任务并发执行的时候,你只需要把这个任务包装成一个函数,开启一个goroutine去执行这个函数。

4、使用goroutine

Go语言中使用goroutine非常简单,只需要在调用函数的时候在前面加上go关键字,就可以为一个函数创建一个goroutine。例如:

func hello() {
    fmt.Println("Hello Goroutine!")
}
func main() {
    go hello() // 启动另外一个goroutine去执行hello函数
    fmt.Println("main goroutine done!")
    time.Sleep(time.Second)
}

执行会先打印main goroutine done!,然后紧接着打印Hello Goroutine!。因为我们在创建新的goroutine的时候需要花费一些时间,而此时main函数所在的goroutine是继续执行的。

参考文章:http://www.topgoer.com/

你可能感兴趣的:(语言,golang协程,goroutine)