真正需要指出的是,这个问题实际上有两个方面 - 理论方面和实施方面 .
首先,让我们看一下理论方面 . 您需要了解流程在概念上是什么,以理解流程和线程之间的差异以及它们之间共享的内容 .
我们从Tanenbaum的Modern Operating Systems 3e中的2.2.2经典线程模型中得到以下内容:
流程模型基于两个独立的概念:资源分组和执行 . 有时将它们分开是有用的;这是线程进来的地方......
他继续:
查看流程的一种方法是将相关资源组合在一起 . 进程具有包含程序文本和数据以及其他资源的地址空间 . 这些资源可能包括打开文件,子进程,待处理警报,信号处理程序,记帐信息等 . 通过以流程的形式将它们组合在一起,可以更轻松地管理它们 . 进程的另一个概念是执行线程,通常简称为线程 . 该线程有一个程序计数器,用于跟踪下一个要执行的指令 . 它有寄存器,它保存当前的工作变量 . 它有一个堆栈,其中包含执行历史记录,每个过程调用一个帧但尚未返回 . 虽然线程必须在某个进程中执行,但线程及其进程是不同的概念,可以单独处理 . 流程用于将资源组合在一起;线程是计划在CPU上执行的实体 .
再向下,他提供了下表:
Per process items | Per thread items
------------------------------|-----------------
Address space | Program counter
Global variables | Registers
Open files | Stack
Child processes | State
Pending alarms |
Signals and signal handlers |
Accounting information |
以上是线程工作所需的内容 . 正如其他人所指出的那样,像段这样的东西是依赖于OS的实现细节 .