操作系统第二次实验:进程控制
16281035
我的github网址,里面有源文件,请查看
实验目的
- 加深对进程概念的理解,明确进程和程序的区别。
- 掌握Linux系统中的进程创建,管理和删除等操作。
- 熟悉使用Linux下的命令和工具,如man, find, grep, whereis, ps, pgrep, kill, ptree, top, vim, gcc,gdb, 管道|等。
基础知识
- 进程的创建
Linux中,载入内存并执行程序映像的操作与创建一个新进程的操作是分离的。将程序映像载入内存,并开始运行它,这个过程称为运行一个新的程序,相应的系统调用称为exec系统调用。而创建一个新的进程的系统调用是fork系统调用。
- exec系统调用
#include <unistd.h>
int execl (const char *path, const char *arg,…);
execl()将path所指路径的映像载入内存,arg是它的第一个参数。参数可变长。参数列表必须以NULL结尾。
通常execl()不会返回。成功的调用会以跳到新的程序入口点作为结束。发生错误时,execl()返回-1,并设置errno值。
例 编辑/home/kidd/hooks.txt:
int ret;
ret = execl (”/bin/vi”, ”vi”,”/home/kidd/hooks.txt”, NULL);
if (ret == -1)
perror (”execl”);
- fork****系统调用
#include <sys/types.h>
#include <unistd.h>
pid_t fork (void);
成功调用fork()会创建一个新的进程,它与调用fork()的进程大致相同。发生错误时,fork()返回-1,并设置errno值。
例:
pid_t pid;
pid = fork ();
if (pid > 0)
printf (”I am the parent of pid=%d!\n”, pid);
else if (!pid)
printf (”I am the baby!\n”);
else if (pid == -1)
perror (”fork”);
- 终止进程
exit()系统调用:
#include <stdlib.h>
void exit (int status);
- 进程挂起
pause() 系统调用:
int pause( void );
函数pause会把进程挂起,直到接收到信号。在信号接收后,进程会从pause函数中退出,继续运行。
- wait(等待子进程中断或结束)
#include<sys/types.h>
#include<sys/wait.h>
pid_t wait (int * status);
wait()会暂时停止目前进程的执行,直到有信号来到或子进程结束。
如果在调用 wait()时子进程已经结束,则wait()会立即返回子进程结束状态值。
子进程的结束状态值会由参数status返回,而子进程的进程识别码也会一起返回。
如果不在意结束状态值,则参数status可以设成 NULL。
VIM常用命令速查
实验题目
1. 打开一个vi进程。通过ps命令以及选择合适的参数,只显示名字为vi的进程。寻找vi进程的父进程,直到init进程为止。记录过程中所有进程的ID和父进程ID。将得到的进程树和由pstree命令的得到的进程树进行比较。
-
首先我先自己创建一个名为VI的vim文件,之后用vim打开
-
打开界面如下:
我在其中启用了编辑命令,编辑了以下内容:
-
保存
-
查看vim进程号,5065
![1552705140843](https://img-blog.csdnimg.cn/20190316114007384.png
-
寻找vim进程的父进程,直到init进程为止。记录过程中所有进程的ID和父进程ID
init进程的pid是1.init进程是其他所有进程的父进程.
列出父进程号是1的进程,就是列出除了init外的所有进程.
所以寻找vim的父进程如下:
5065 -> 4626 -> 4619 -> 908 -> 1
-
将得到的进程树和由pstree命令的得到的进程树进行比较。
两个相比较,是一样的结果: 5065 -> 4626 -> 4619 -> 908 -> 1