程序binary program
放置在存储媒体中(如硬盘、光盘、软盘、磁带等),为实体文件的形态存在;
进程Process
程序被触发后,执行者的权限与属性、程序的程序代码与所需数据等都会被加载内存中,操作系统并给予这个内存内的单元一个标识符(PID),可以说,进程就是一个正在运作中的程序。
如何查看系统中的进程
a. 使用top命令
b.使用ps命令,一般结合grep使用
top //查找进程
ps -aux //查找所有的进程
ps -aux|grep init //查找init进程
线程thread
是操作系统能够进行运算调度的最小单位。它被包含在进程之中,是进程中的实际运作单位。一条线程指的是进程中一个单一顺序的控制流,一个进程中可以并发多个线程,每条线程并行执行不同的任务。
线程是独立调度和分派的基本单位。
线程可以为操作系统内核调度的内核线程,如Win32线程;由用户进程自行调度的用户线程,如Linux平台的POSIX Thread;或者由内核与用户进程,如Windows 7的线程,进行混合调度。
同一进程中的多条线程将共享该进程中的全部系统资源
,如虚拟地址空间,文件描述符和信号处理等等。
进程与线程的区别
1)根本区别:
进程时操作系统资源分配的基本单位;线程是任务调度和执行的基本单位。
2)开销方面:
每个进程都有独立的代码和数据空间,程序之间的切换会有较大的开销;线程可以看成是轻量级的进程同一类线程共享代码和数据空间,每个线程都有自己独立的运行栈和程序计数器(PC),线程之间切换的开销小。
3)所处环境:
在操作系统中能同时运行多个进程(程序);而在同一个进程中有多个线程同时执行(通过CPU调度,在每个时间片中只有一个线程执行)。
4)内存分配方面:
系统在运行的时候会为每个进程分配不同的内存空间;而对进程而言,除CPU外,系统不会为线程分配内存(线程所使用的资源都来自其所属进程的资源),线程组之间只能共享资源。
5)包含关系:
没有开辟线程的进程可以看作是单线程的,一个进程至少有一个线程,如果一个进程内有多个线程,则执行过程不是一条线的,而是多条线(线程)共同完成的;线程是进程的一部分,所以线程也被称为轻权进程或轻量级进程。
简记:
进程与线程的区别:合租住房分配开销是根本
合租->包含关系:进程一对一为单线程,进程一对多完成多任务;线程是进程的一部分。
住房->所处环境:操作系统中可以同时运行多个进程;统一进程中有多个线程同时执行。
分配->内存分配:对进程而言,除CPU外,系统不会为线程分配内存,线程组之间只能共享资源。
开销->开销方面:进程有独立的代码和数据空间,程序之间的切换开销大;线程有独立的运行栈和程序计数器,线程之间切换的开销小。
根本->根本区别:进程时操作系统资源分配的基本单位;线程是任务调度和执行的基本单位。