c++学习:程字辈(进程、线程、协程)
程字辈(进程、线程、协程)
介绍 C++ 中的进程、线程、协程之间的联系及区别。(以 linux 下实现为例)
进程
概念: 进程是具有一定独立功能的程序关于某个数据集合上的一次运行活动,进程是系统进行资源分配和调度的一个独立单位。每个进程都有自己的独立内存空间,不同进程通过进程间通信来通信。
- 由于进程比较重量,占据独立的内存,所以上下文进程间的切换开销(栈、寄存器、虚拟内存、文件句柄等)比较大,但相对比较稳定安全。
linux 多进程
在Linux中,创建进程有如下两个目的:
- 将同一个程序分成多个进程进行处理(例如:使用Web服务器接收多个请求)
- 创建另一个程序(例如:从bash启动一一个新的程序)
在 Linux 下进程管理主要通过以下三个函数:
- fork():从父进程拷贝生成一个子进程。
- system():会调用fork函数产生子进程,由子进程来执行command命令,命令执行完后随即返回原调用的进程。例如:
system("./a");
: 相当于在终端输入./a,也就是运行这个程序
- exec():exec函数是直接覆盖掉当前进程,也就是说,并没有增加新进程,而只是替换了当前进程。主要的作用如下所示:
- 读取可执行文件,并读取创建进程的内存映像所需的信息。
- 用新进程的数据覆盖当前进程的内存。
- 从最初的命令开始运行新的进程。
三者的区别联系实现参考:Linux——进程管理篇(详解fork和exec)
linux网络编程:如何使用多进程、多线程及优缺点
线程
概念: 线程是进程的一个实体,是CPU调度和分派的基本单位,它是比进程更小的能独立运行的基本单位。
- 线程自己基本上不拥有系统资源,只拥有一点在运行中必不可少的资源(如程序计数器,一组寄存器和栈),但是它可与同属一个进程的其他的线程共享进程所拥有的全部资源。
- 线程间通信主要通过共享内存,上下文切换很快,资源开销较少,但相比进程不够稳定容易丢失数据。线程私有的资源包含:线程ID、寄存器组的值、线程的栈、错误返回码errno值、线程的信号屏蔽码、线程的优先级--可以自己设置优先级。
协程
概念: 协程是一种用户态的轻量级线程,协程的调度完全由用户控制。
- 协程拥有自己的寄存器上下文和栈。协程调度切换时,将寄存器上下文和栈保存到其他地方,在切回来的时候,恢复先前保存的寄存器上下文和栈,直接操作栈,基本没有内核切换的开销,可以不加锁的访问全局变量,所以上下文的切换非常快。
- 协程只能调用非阻塞接口,当调用阻塞接口时,整个线程都被阻塞,(线程中实现协程 常用的两个API则是setjump,保存当前的堆栈,longjump跳转到指定的位置)。
对比
1、进程与线程的比较
线程是指进程内的一个执行单元,也是进程内的可调度实体。线程与进程的区别:
- 地址空间:线程是进程内的一个执行单元,进程内至少有一个线程,它们共享进程的地址空间,而进程有自己独立的地址空间
- 资源拥有:进程是资源分配和拥有的单位,同一个进程内的线程共享进程的资源
- 线程是处理器调度的基本单位,但进程不是
- 二者均可并发执行
- 每个独立的线程有一个程序运行的入口、顺序执行序列和程序的出口,但是线程不能够独立执行,必须依存在应用程序中,由应用程序提供多个线程执行控制。
2、协程与线程进行比较
- 一个线程可以多个协程,一个进程也可以单独拥有多个协程
- 线程进程都是同步机制,而协程则是异步
- 协程能保留上一次调用时的状态,每次过程重入时,就相当于进入上一次调用的状态
ref
进程,线程,协程讲解
Linux——进程管理篇(详解fork和exec)
linux网络编程:如何使用多进程、多线程及优缺点