【1】程序,进程,线程的区别
程序:程序是一个静态的代码,是保存在存储器上的指令和数据的有序的集合,没有执行的概念。
进程:进程是一个动态的概念,他是程序一次执行的过程,包括动态的创建,调度,执行和消亡的整个过程,是程序执行和资源管理的最小单位。
线程(轻量级进程):线程可以对进程的内存空间和资源进行访问,并与同一进程中的其他线程共享,线程的开销比进程小的多。一个进程可以拥有多个线程。
【2】进程的概念
1.进程的内存管理:正文段,用户数据段,系统数据段
2.进程号PID:一个PID号码标识一个进程
3.进程的特性:
(1)并发性:系统中多个进程可以同时并发运行,相互之间互不干扰。
(2)动态性:进程具有完整的生命周期,在生命周期内进程的状态是不断改变的,进程具有动态的地址空间。
(3)交互性:进程间可以进行通信,如进程的同步和互斥等。
(4)独立性:进程是一个完整的资源分配和调度的基础单位,各各进程的地址空间相互独立,采用特定的通信机制才能进行进程间通讯。
【2】线程的概念
进程是系统中程序执行和资源分配的基本单位,每个进程都有自己的数据段,代码段和堆栈段,因此进程在切换时消耗巨大。为了提高效率,引进线程概念。线程可以对进程的内存空间和资源进行访问并与其他线程共享。一个进程可以具有多个线程。
-
每个用户进程有自己的虚拟地址空间。系统为每个用户进程创建一个 task_struct 来描述该进程 struct task_struct。task_struct 和地址空间映射表一起用来表示一个进程。由于进程的虚拟地址空间是私有的,因此进程切换开销很大。为了提高系统的性能,linux引入轻量级进程, 起名为线程。
-
在同一个进程中创建的线程共享该进程的地址空间。Linux里同样用task_struct来描述一个线程。