实验六进程控制

上传人:大米 文档编号:560574485 上传时间:2023-05-23 格式:DOCX 页数:6 大小:18.99KB
返回 下载 相关 举报
实验六进程控制_第1页
第1页 / 共6页
实验六进程控制_第2页
第2页 / 共6页
实验六进程控制_第3页
第3页 / 共6页
实验六进程控制_第4页
第4页 / 共6页
实验六进程控制_第5页
第5页 / 共6页
点击查看更多>>
资源描述

《实验六进程控制》由会员分享,可在线阅读,更多相关《实验六进程控制(6页珍藏版)》请在金锄头文库上搜索。

1、精选优质文档-倾情为你奉上实验六、进程控制一、实验目的 1.实践并发进程的创建和控制方法。观察和体验进程的动态特性。2.进一步理解进程生命期期间创建、变换、撤销状态变换的过程。3.练习 Linux 系统中进程创建与控制有关的系统调用的编程和调试技术。 二、 实验说明 1)与进程创建、执行有关的系统调用说明 进程可以通过系统调用fork()创建子进程并和其子进程并发执行.子进程初始的执行映像是父进程的一个副本.子进程可以通过 exec()系统调用族装入一个新的执行程序。父进程可以使用wait()或waitpid()系统调用等待子进程的结束并负责收集和清理子进程的退出状态。 fork()系统调用语

2、法: #include pid_t fork(void); fork 成功创建子进程后将返回子进程的进程号,不成功会返回-1. exec 系统调用有一组 6个函数,其中示例实验中引用了execve 系统调用语法: #include int execve(const char *path, const char *argv, const char * envp); path 要装入的新的执行文件的绝对路径名字符串. argv 要传递给新执行程序的完整的命令参数列表(可以为空). envp 要传递给新执行程序的完整的环境变量参数列表(可以为空). exec执行成功后将用一个新的程序代替原进程,但进

3、程号不变,它绝不会再返回到调用进程了。如果 exec 调用失败,它会返回-1。 wait() 系统调用语法: #include #include pid_t wait(int *status); pid_t waitpid(pid_t pid,int *status,int option); status 用于保留子进程的退出状态 pid 可以为以下可能值: -1 等待所有PGID等于PID的绝对值的子进程 1 等待所有子进程 0 等待所有PGID等于调用进程的子进程 0 等待PID等于pid 的子进程 option 规定了调用 waitpid 进程的行为: WNOHANG 没有子进程时立即返

4、回 WUNTRACED 没有报告状态的进程时返回 wait和 waitpid 执行成功将返回终止的子进程的进程号,不成功返回-1。 getpid()系统调用语法: #include #include pid_t getpid(void); pid_t getppid(void); getpid返回当前进程的进程号,getppid 返回当前进程父进程的进程号 2) 与进程控制有关的系统调用说明 可以通过信号向一个进程发送消息以控制进程的行为。信号是由中断或异常事件引发的,如:键盘中断、定时器中断、非法内存引用等。信号的名字都以 SIG 开头,例如 SIGTERM、SIGHUP。可以使用 kill

5、 -l 命令查看系统当前的信号集合。 信号可在任何时间发生,接收信号的进程可以对接收到的信号采取3种处理措施之一: 忽略这个信号 执行系统默认的处理 捕捉这个信号做自定义的处理 信号从产生到被处理所经过的过程: 产生(generate)-挂起(pending)-派送(deliver)-部署(disposition)或忽略(igore) 一个信号集合是一个C 语言的 sigset_t数据类型的对象,sigset_t数据类型定义在中。被一个进程忽略的所有信号的集合称为一个信号掩码(mask)。 从程序中向一个进程发送信号有两种方法:调用 shell的 kill命令,调用kill系统调用函数。kil

6、l能够发送除杀死一个进程(SIGKILL、SIGTERM、SIGQUIT) 之外的其他信号,例如键盘中断(Ctrl+C)信号SIGINT,进程暂停(Ctrl+Z)信号SIGTSTP 等等。 调用 pause 函数会令调用进程的执行挂起直到一个任意信号到来后再继续运行。 调用 sleep 函数会令调用进程的执行挂起睡眠指定的秒数或一个它可以响应的信号到来后继续执行。 每个进程都能使用 signal 函数定义自己的信号处理函数,捕捉并自行处理接收的除SIGSTOP和SIGKILL之外的信号。以下是有关的系统调用的语法说明。 kill系统调用语法: #include #include int kil

7、l(pid_t pid, int sig); pid 接收信号的进程号 signal 要发送的信号 kill发送成功返回接收者的进程号,失败返回-1。 pause系统调用语法: include int pause(void); pause 挂起调用它的进程直到有任何信号到达。调用进程不自定义处理方法,则进行信号的默认处理。只有进程自定义了信号处理方法捕获并处理了一个信号后,pause 才会返回调进程。pause 总是返回-1,并设置系统变量errno为 EINTR。 sleep 系统调用语法: #include unsigned int sleep(unsigned int seconds);

8、 seconds 指定进程睡眠的秒数 如果指定的秒数到,sleep返回 0。 signal系统调用语法为: #include typedef void (*sighandler_t)(int); sighandler_t signal(int signum, sighandler_t handler); signum 要捕捉的信号 handler 进程中自定义的信号处理函数名 signal 调用成功会返回信号处理函数的返回值,不成功返回-1,并设置系统变量errno 为SIG_ERR。三、实验内容与步骤 以下实验示例程序应实现一个类似子 shell子命令的功能,它可以从执行程序中启动另一个新的

9、子进程并执行一个新的命令和其并发执行. 1) 打开一终端命令行窗体,新建一个文件夹,在该文件夹中建立以下名为pctl.c的C语言程序: /* * Filename : pctl.c * copyright : (C) 2006 by zhanghonglie * Function : 父子进程的并发执行 */ #include pctl.h int main(int argc, char *argv) int i; int pid; /存放子进程号 int status; /存放子进程返回状态char *args = /bin/ls,-a,NULL; /子进程要缺省执行的命令 signal(S

10、IGINT,(sighandler_t)sigcat); /注册一个本进程处理键盘中断的函数 pid=fork() ; /建立子进程 if(pid0) / 建立子进程失败? printf(Create Process fail!n); exit(EXIT_FAILURE); if(pid = 0) / 子进程执行代码段 /报告父子进程进程号 printf(I am Child process %dnMy father is %dn,getpid(),getppid(); pause(); /暂停,等待键盘中断信号唤醒 /子进程被键盘中断信号唤醒继续执行 printf(%d child will

11、 Running: n ,getpid(); / if(argv1 != NULL) /如果在命令行上输入了子进程要执行的命令 /则执行输入的命令 for(i=1; argvi != NULL; i+) printf(%s ,argvi); printf(n); /装入并执行新的程序 status = execve(argv1,&argv1,NULL); else /如果在命令行上没输入子进程要执行的命令 /则执行缺省的命令 for(i=0; argsi != NULL; i+) printf(%s ,argsi); printf(n); /装入并执行新的程序 status = execve(

12、args0,args,NULL); else /父进程执行代码段 printf(nI am Parent process %dn,getpid(); /报告父进程进程号 if(argv1 != NULL) /如果在命令行上输入了子进程要执行的命令 /则父进程等待子进程执行结束 printf(%d Waiting for child done.nn); waitpid(pid,&status,0); /等待子进程结束 printf(nMy child exit! status = %dnn,status); else /如果在命令行上没输入子进程要执行的命令 /唤醒子进程,与子进程并发执行不等待子进程执行结束, if(kill(pid,SIG

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 办公文档 > 教学/培训

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号