进程线程协程的区别?
进程是操作系统分配资源的基本单位。线程是CPU调度资源的基本单位。协程可以理解为用户态线程,是微量级线程。协程的调度是在用户态下进行,不需要切换到内核态,所以不由操作系统参与,由用户自己控制。协程有独立的栈空间,但是共享堆空间。一个进程可以跑多个线程,一个线程可以跑多个协程。
进程和线程的上下文切换由操作系统内核控制,代价较高,因为需要保存和恢复大量的状态信息。协程的上下文切换由用户代码控制,代价较低,因为只需要保存和恢复很少的状态信息。
协程是什么?
Go语言通过goroutine和channel来简化并发编程,一个goroutine通常只有几kb的栈空间,并且会根据需求动态增长,使得数以万计的goroutine运行在单个系统上也是现实可行的。另外,Go的调度器能有效地将goroutine映射到操作系统的线程上,进一步提升了并发性能。