进程:
进程(Process)是计算机中的程序关于某数据集合上的一次运行活动,是系统进行资源分配和调度的基本单位,是操作系统结构的基础。在早期面向进程设计的计算机结构中,进程是程序的基本执行实体;在当代面向线程设计的计算机结构中,进程是线程的容器。程序是指令、数据及其组织形式的描述,进程是程序的实体。
线程:
线程(英语:thread)是操作系统能够进行运算调度的最小单位。它被包含在进程之中,是进程中的实际运作单位。一条线程指的是进程中一个单一顺序的控制流,一个进程中可以并发多个线程,每条线程并行执行不同的任务。线程是独立调度和分派的基本单位。
线程可以当成小的线程。同时同一进程中的多条线程将共享该进程中的全部系统资源,如虚拟地址空间等等,所以他们之间的切换开销会比较小。但同一进程中的多个线程有各自的调用栈(call stack),自己的寄存器环境(register context),自己的线程本地存储(thread-local storage)。
根本区别:
- 进程是操作系统资源分配的基本单位,而线程是任务调度和执行的基本单位。
- 一个进程可以有多个线程,操作系统中能同时运行多个进程。
- 操作系统会给进程分配内存,但是不会给线程分配,线程共享进程资源。