Day1:
一 进程相关
1 程序和进程
程序:是保存在磁盘上实现了某个功能的代码模块,包含代码逻辑和数据,没有运行的概念,是静态的。
进程:是程序的一次动态执行过程,进程是程序执行和资源管理的最小单位。是动态的包含代码逻辑、数据、系统资源。
2进程的标识
进程号pid:唯一标识一个进程的符号 ps -aux
父进程号ppid:标识当前进程父进程的符号
将一个程序放到操作系统中,该程序就变成了一个进程,操作系统为该进程分配 一个task_struct来标识它,同时给它分配4G的虚拟内存空间。
进程=task_struct+4G(虚拟内存)
linux系统中的task_struct是PCB的一种,是一个描述进程的结构体,
主要内容有:
1 标识符--》pid
2 状态
3 优先级
4 程序计数器(pc)
5 内存指针
。。。。
3进程类型
linux系统中的进程类型:
1 交互进程:给指令有回应的进程 ps ls
2 批处理进程:是一个进程的集合,维护者一个进程队列,负责按顺序启动队列中的进程。
shutdown -h time
3 守护进程:周期性的执行某项任务或等待某个事件发生的进程,不依赖shell中断,生存周期较长。(从开机开始到关机结束)
4 进程相关指令
ps -aux:查看系统中运行的进程
ps -axj:查看系统中运行的进程
top:动态查看进程
pstree:查看进程树
kill:关闭一个进程 Kill -9 进程号
nice:以指定的优先级运行进程 nice -20 ./a.out <-20~19>
renice:改变正在运行的程序的优先级
5 进程的状态
一般来说,Linux系统中的进程有三种状态:运行态 等待态 停止态(kill -STOP pid),进程的以上三种状态可以切换
Linux中进程的七种状态:
1 R运行状态(runing):并不意味着进程一定在运行中,也可以在运行队列中
2 S睡眠状态(sleeping):进程在等待时间完成(浅度睡眠,可以被唤醒)
3 D 磁盘睡眠状态(disk sleep):不可中断睡眠(深度睡眠,不可以被唤醒,通常在磁盘写入时发生)
4 T 停止状态(stopped):可以通过发送stop信号给进程来停止进程,可以发送SIGCONT信号让进程继续运行。
5 X 死亡状态(dead):该状态为返回状态,在任务列表中看不到
6 Z 僵尸状态(zombie):子进程退出,父进程还在运行,但是父进程没有读到子进程的退出状态值,子进程进入僵尸状态。
7 t追踪停止状态(trancing stop)
6 进程的启动方式
两种:1 手工启动 ls -l ./a.out
2 调度启动:
/etc/init.d/rcS-->自动启动某些应用程序
at:在一个指定的时间执行一个任务 at 12:00 shutdown -S -T30
二 进程相关的函数 --》fork exec函数族 exit/_exit wait/waitpid
1 fork
作用:创建一个子进程
(创建方式:子进程复制了父进程的所有的内容,他和父进程的进程号不同)
pid_t fork(void);
无入参
返回值:创建失败,-1
创建成功 0或pid(0->子进程 子进程的进程号pid---》父进程)
孤儿进程:父进程先于子进程退出,子进程由init进程收养,此时的子进程就是孤儿进程,pstree查看。孤儿进程可单独存在,没有危害
僵尸进程:子进程先于父进程退出,父进程未处理子进程的退出状态,导致该子进程成为一个僵尸进程,僵尸进程占用一个task_struct,但是没有相 应的地址空间,它会统一参与操作系统的调度,会消耗系统资源,对系统有危害,我们应当避免僵尸进程的产生。ps -aux查看
2 exec函数族--》替换进程(在一个进程中启动另外一个进程,另外这个进程 使用当前进程的所有资源)
有6个函数,作用相同,传参方式不同。传参方式由 l v p e组合而成
l:list 以列表的方式传参,最后以NULL结束
v:vector以数组方式传参,数组的最后一个元素为NULL
e:env环境变量,传参方式同数组
p:PATH,在PATH所指的路径中去找可执行程序
3 exit/_exit
exit:退出当前进程,并刷新IO缓存区
参数1:表示退出状态值。0表示正常退出,其他为异常退出
_exit:退出当前进程,不会刷新IO缓存区
WEXITSTATUS(status):提取子进程的返回状态值的低8位
4 wait/waitpid
wait:等待子进程退出(任意子进程),接收子进程的退出状态值。
pid_t wait(int *status);
*status:指向等到的子进程的退出状态值的指针
返回值:>0 等到的子进程的pid
-1 出错
注意:wait是一个阻塞函数
waitpid:等待指定子进程的退出状态值,接收子进程的退出状态值。
pid_t waitpid(pid_t pid, int *status, int options);
pid:指定子进程的pid
*status:指向等到的子进程的退出状态值的指针
options:0 : 将waitpid函数变成了阻塞函数
WNOHANG:将waitpid函数变成了非阻塞函数,若等到结果
返回等到的子进程的pid,若未等到结果,返回0
返回值:未等到结果,返回0
等到结果,返回等到的指定子进程的pid
阻塞函数:未等到结果,不返回,会一直阻塞当前进程,直到等到结果再返回
非阻塞函数:未等到结果,也返回,不影响当前进程的执行,通过多次循环调用
非阻塞函数去等结果。