进程、线程、协程的区别和联系

Scroll Down

区别

  • 进程是系统进行资源费配和调度的一个独立单位。
  • 线程是进程的一个实体,是CPU调度和分派的基本单位。它是比进程更小的能独立运行的基本单位.线程自己基本上不拥有系统资源,只拥有一点在运行中必不可少的资源(如程序计数器,一组寄存器和栈),但是它可与同属一个进程的其他的线程共享进程所拥有的全部资源.
  • 线程执行开销小,但不利于资源的管理和保护;而进程正相反。
  • 一个程序至少有一个进程,一个进程至少有一个线程。
  • 进程切换的资源最大,效率低。
  • 线程切换的资源一般,效率一般。
  • 协程切换任务资源最小,效率最高。
  • 多进程、多线程根据CPU核心数不同可能是并行的,协程在一个线程中是并发的。

什么是并行?
你吃饭吃到一半,电话来了,你一边打电话一边吃饭,这说明你支持并行。 并行的关键是你有同时处理多个任务的能力。
什么是并发?
你吃饭吃到一半,电话来了,你停了下来接了电话,接完后继续吃饭,这说明你支持并发。并发的关键是你有处理多个任务的能力,不一定要同时。

联系

  • 都能完成多任务。