有关线程进程协程

Posted hexinghao

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了有关线程进程协程相关的知识,希望对你有一定的参考价值。

    进程是具有一定独立功能的程序关于某个数据集合上的一次运行活动,进程是系统进行资源分配和调度的一个独立单位,每个进程都有自己的独立内存空间,不同进程通过进程间通信来通信。由于进程比较重量,占据独立的内存,所以上下文进程间的切换开销(栈,寄存器,虚拟内存,文件句柄等)比较大,但相对比较安全稳定。

    线程是进程的一个实体,是cpu调度和分派的接班单位,它是比进程更小的能独立运行的基本单位,线程自己基本上不拥有系统资源,只拥有一点在运行中必不可少的资源(如程序计数器,一组寄存器和栈),但是它可与同属一个进程的其他的线程共享进程所拥有的的全部资源。线程间通信主要通过共享内存,上下文切换,资源开销较少,但相比进程,不够稳定,容易丢失数据。

    协程是一种用户态的轻量级线程,协程的调度完全有用户控制。协程拥有自己的寄存器上下文和栈。协程调度切换时,将寄存器上下文和栈保存到其他地方,在切回来的时候,恢复嫌弃那保存的寄存器上下文和栈,直接操作栈则基本没有内核切换的开销,可以不加锁的访问全局变量,所以上下文的切换非常快。

以上是关于有关线程进程协程的主要内容,如果未能解决你的问题,请参考以下文章

Python 中的进程线程协程同步异步回调

进程线程协程

进程线程协程的区别

进程线程协程

初识进程 线程 协程:协程

Python之进程线程协程篇