谈谈对进程、线程、协程的理解

进程是程序在计算机上的一次动态运行,是系统分配资源的最小单位。而线程被称为轻量级的进程,与进程是包含关系,一个进程可以包含多个线程。线程是系统分配内核的最小单位,创建线程所消耗的资源远小于进程。多个进程拥有各自的独立空间存放数据,互不干扰,有专门的进程间通信方法。而多个线程由于共享一个进程的资源,只能使用全局变量进行通信,在操作共享资源时往往采用同步互斥的方式,在操作前上一个线程锁,操作完后释放这个线程锁来保证同一时间只有一个线程操作数据。

协程也被成为纤程和微线程,本质上是一个可以暂停执行的函数,通过记录暂停时的上下文,在阻塞结束后可以回到记录的地方继续执行下去,通过协程来回的切换,使得程序可以异步地执行阻塞事件。而且协程的切换直接在应用层完成,消耗的资源比线程小得多,由于是单线程程序,无需进行同步互斥的处理,唯一的缺点就是无法利用计算机的多核资源。

猜你喜欢

转载自blog.csdn.net/qq_43435274/article/details/103625299
今日推荐