本文图片均来自王道考研
一、进程的概念、组成和特征
进程(Process)是计算机中的一个核心概念,它是对正在运行的程序的一个抽象表示。在计算机科学中,一个进程是系统进行资源分配和调度的一个独立单元,是操作系统结构的基础。简而言之,进程是操作系统进行资源管理的最小单位,是系统进行并发执行的基本单位,是独立运行的程序实体。
进程包含了运行一个程序所需的所有信息,包括程序代码、当前执行到哪条指令、程序运行时的数据(变量)、系统状态(如打开的文件、内存信息等)以及进程控制块(PCB,Process Control Block)等。PCB是操作系统用于记录进程状态的重要数据结构,它包含了进程的各种信息,如进程标识符(PID)、进程状态(就绪、运行、阻塞等)、程序计数器、CPU寄存器、内存管理信息、输入输出状态信息、会计信息(如CPU时间、实际使用时间等)等。
进程的特性
- 动态性:进程是程序的一次执行过程,是动态产生、变化和消亡的。
- 并发性:多个进程可以在一段时间内同时运行,但它们的逻辑上是独立的。
- 独立性:进程是系统进行资源分配和调度的独立单元,每个进程都拥有自己独立的地址空间。
- 异步性:进程按各自独立的、不可预知的速度向前推进,操作系统负责进程间的同步和通信。
- 结构性:进程由程序、数据和PCB三部分组成。
进程与程序的区别
- 程序是静态的,是存储在硬盘上的可执行的二进制代码;进程是动态的,是程序执行的过程,包括动态创建、调度和消亡。
- 同一个程序可以产生多个进程,进程是程序的一次执行实例。
- 进程是系统进行资源分配和调度的独立单元,每个进程都有独立的内存空间和系统资源。
进程的状态
进程在其生命周期中会经历多种状态,常见的进程状态包括:
- 新建(New):进程正在被创建。
- 就绪(Ready):进程已准备好,等待CPU分配。
- 运行(Running):进程正在CPU上执行。
- 阻塞(Blocked):进程因为等待某个事件发生(如I/O操作)而暂停执行。
- 终止(Terminated):进程已完成执行或被系统终止。
二、进程的状态与转换
三、进程控制
四、进程通信(IPC)
五、线程概念、多线程模型
线程是计算机科学中的一个基本概念,指的是在一个进程中执行的独立指令流。它是程序执行的最小单位,是进程的一个实体,也是系统独立调度和分派的基本单位。具体来说,线程具有以下特点:
定义与基本属性
- 定义:线程是进程中负责执行的具体任务,即进程内部的执行序列或执行路线。
- 资源共享:线程之间共享进程的代码段、数据段、堆、环境变量表、命令行参数、文件描述符、信号处理方式等资源(除了栈之外),这使得线程之间的数据交换和通信更为直接和高效。
- 独立执行:虽然线程共享进程的资源,但每个线程都有自己独立的线程ID、寄存器信息、函数栈、错误码等,可以独立执行不同的任务。
线程与进程的关系
- 进程是资源分配的最小单位:每个进程都拥有独立的虚拟地址空间,用于存储程序代码和数据。
- 线程是调度的最小单位:操作系统通过线程来分配CPU时间片,实现任务的并发执行。一个进程可以包含多个线程,这些线程在进程内部并发执行,共享进程的资源。
线程的状态与操作
- 线程状态:线程在其生命周期中会经历多种状态,如新建、就绪、运行、阻塞和终止等。系统通过管理线程的状态来实现线程的调度和同步。
- 线程操作:系统提供了多种线程控制原语,如创建线程、取消线程、销毁线程等。程序员可以通过这些操作来创建和管理线程,实现复杂的并发编程任务。
线程的优势与挑战
- 优势:线程能够提高程序的响应性和并发性,充分利用多核处理器的计算能力。同时,由于线程之间共享进程的资源,因此可以减少数据复制和传输的开销,提高程序的执行效率。
- 挑战:多线程编程也带来了一些挑战,如竞态条件、死锁等问题。这些问题可能导致程序出现错误或不稳定的行为。因此,在设计和实现多线程程序时,需要仔细考虑线程之间的同步和互斥机制,以确保程序的正确性和稳定性。