emacs -nw & // 加&将程序放在后台执行
jobs // 显示后台所有进程
ps // 显示当前终端进程 相当于任务管理器
ps -U 当前用户登录名 // 列出指定用户名所有的进程
ps -e // 显示用户所有进程
ps -l // 显示完整的终端信息<PID = Process ID> <PPID = Parent Process ID><PRI = Priority><NI = Nice>
windows多用户抢先式多用户操作系统:优先级高进程抢夺优先级低进程资源。
nice值:抢先式OS中会出现进程饿死的现象<低优先级获取不到CPU资源>。为了避免这种现象,在一段时间内得不到资源的低优先级进程级别将提升,增加的优先级次数为nice值。
如何在程序中启动进程:
<参数>OS会自动将函数名后的参数转换为argv参数。
<启动进程过程>
1.帮助进程分析参数列表
2.把进程的环境变量传递给进城
<从进程中退出>
1.从main函数中显示返回,return 0;
2.隐示返回,函数返回void,void main();
3.调用exit()函数;
<启动新的进程>
1.使用system函数
#include <stdlib.h>
int system(const char *command)
eg: system("ls"); // 前台启动
eg: system("gedit &"); // 后台启动
system进程没有退出前之后的操作不执行。
是同步函数,必须等待前台子进程退出才返回;对于后台子进程又没有同步机制;它实际是启动一个新的shell来创建子进程的,效率很低。
2.exec家族
execl:使用绝对路径。可变参数列表
execlp:从PATH环境变量里面查找要执行的环境变量文件
execv:直接传入main.
exec启动新的进程,完全替换老的进程。后面的不执行。
3.fork可以启动一个子进程,子进程与父进程一样(只有PID不一样)
僵尸进程:
1.父进程删除在进程表中子进程
①父进程正常退出
②父进程调用wait函数
pid_t wait(int *stat_loc)
父进程可以有多个子进程。不需要子进程返回值传NULL值。
文件系统/proc文件夹中列出了进程的所有信息。
exec使用其他进程替换自己,fork复制自己的一个备份。