进程和程序的区别
我们都知道程序在Linux系统中是一系列代码、数据的表示形式,当我们没有运行它时,程序以源程序的形式存储在外存(比如硬盘、U盘等)中,只有运行的时候才会被载入内存。在程序开始运行后,系统将为这个程序分配指定的内存空间,此时程序将执行对应的指令,而这个过程称为进程。系统为了确保各个进程间不被互相影响,确保同时运行的程序之间不会相互干扰,系统对进程做出以下设定:
- 操作系统以进程为单位,为每个进程分配执行所需要的资源;
- 原则上,各个进程之间不允许访问对方的资源;
- 操作系统实时监控着每个进程的执行状态,必要时可以强制其终止执行。
虽然系统为了进程做出以上设定,方便了系统对管理,但是在系统中如果仅存在进程,将无法满足日常的内存需要,因为进程存在着如下几个问题:
- 在Linux系统下,启动一个新的进程必须分配给它独立的地址空间,建立众多的数据表来维护它的代码段、堆栈段和数据段,这是一种"昂贵"的多任务工作方式。
- 对不同进程来说,它们具有独立的数据空间,要进行数据的传递只能通过通信的方式进行,这种方式不仅费时,而且很不方便。
为此,线程应运而生。线程是操作系统能够进行运算调度的最小单位。它被包含在进程之中,是进程中的实际运作单位。一条线程指的是进程中一个单一顺序的控制流,一个进程中可以并发多个线程,每条线程并行执行不同的任务。