进程与程序
程序:保存在磁盘空间中的的一段代码的集合
进程:是一个程序动态执行的过程,包括进程的创建、调度和消亡的过程
进程相关的命令
PID:进程的标识符(进程的ID)
PPID:父进程的ID号
1.top
根据CPU占用率查看进程信息
2.ps -ef ps -ef | grep a.out
查看当前所有进程的信息
3.ps -aux ps -aux | grep a.out
查看当前所有进程的信息
4.kill 向进程发送信号,并让进程结束
kill -l 查看信号的类型
kill -信号名/信号编号 进程ID
kill -9 进程ID
killall -信号名/信号编号 进程名
5.后台运行代码: ./a.out &
6.jobs
查看后台执行的任务
7.fg 任务编号
将任务编号对应的后台任务放到前台执行
8.nice
nice -n 10 ./a.out
以10作为优先级运行a.out进程 在Linux系统中数字越小优先级越高
9.renice
renice -n 10 进程ID
10.pstree
查看进程的关系
进程的创建
虚拟内存空间分为:
用户空间:
1.文本段:文本区 存放代码、指令
2.数据段:数据区 存放全局变量、静态变量、常量
3.系统数据段:堆、栈
内核空间:
1.用户无法访问内核空间,通过信号、系统调用实现用户层和内核层的交互
实际物理内存空间:
MMU内存映射单元实现虚拟地址和物理地址间的映射关系
4.进程的调度:
进程调度算法:
1.顺序执行
2.高优先级调度算法
3.时间片轮转调度算法
4.抢占式调度算法
5.多级反馈队列调度算法
时间片:
CPU在一个进程任务中执行的时间称为时间片
宏观并行、微观串行
进程的状态:
1.运行态、就绪态: R
运行态:正在被CPU执行的进程任务
就绪态:正在执行的任务,但由于CPU调度还没有被调度到
2.可唤醒等待态: S
睡眠态
由于缺少资源导致程序阻塞的状态,当拿到资源后,继续向下执行
3.不可唤醒等待态: D
不想被CPU任务调度打断
4.暂停态 T
用户主动让进程任务暂停(挂起)状态
5.僵尸态 Z
进程任务结束了,但空间没有被回收
6.结束态 X
进程任务执行完了,空间被回收
5.进程相关的函数接口:
1.fork
pid_t fork(void);
功能:
创建一个子进程
参数:
void 缺省
返回值:
创建失败返回-1
成功父进程中返回创建的子进程的PID
子进程中返回0
写时拷贝:fork创建子进程,子进程拷贝父进程中的数据,如果只是读取时不会为子进程单独生成空间,只有做写入操作时,才会
为子进程开辟独立空间,提高进程创建的效率
2.getpid
pid_t getpid(void);
功能:
获取进程的PID
3.getppid
pid_t getppid(void);
功能:
获得父进程的PID
2.exit
void exit(int status);