- 1、本文档共6页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
实验六进程控制.
实验六、进程控制
一、实验目的
1.实践并发进程的创建和控制方法。观察和体验进程的动态特性。
2.进一步理解进程生命期期间创建、变换、撤销状态变换的过程。
3.练习 Linux 系统中进程创建与控制有关的系统调用的编程和调试技术。
二、 实验说明
1)与进程创建、执行有关的系统调用说明
进程可以通过系统调用fork()创建子进程并和其子进程并发执行.子进程初始的执行映像是父进程的一个副本.子进程可以通过 exec()系统调用族装入一个新的执行程序。父进程可以使用wait()或waitpid()系统调用等待子进程的结束并负责收集和清理子进程的退出状态。
fork()系统调用语法:
#include unistd.h
pid_t fork(void);
fork 成功创建子进程后将返回子进程的进程号,不成功会返回-1.
exec 系统调用有一组 6个函数,其中示例实验中引用了execve 系统调用语法:
#include unistd.h
int execve(const char *path, const char *argv[], const char * envp[]);
path 要装入的新的执行文件的绝对路径名字符串.
argv[] 要传递给新执行程序的完整的命令参数列表(可以为空).
envp[] 要传递给新执行程序的完整的环境变量参数列表(可以为空).
exec执行成功后将用一个新的程序代替原进程,但进程号不变,它绝不会再返回到调用进程了。如果 exec 调用失败,它会返回-1。
wait() 系统调用语法:
#include sys/types.h
#include sys/wait.h
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 没有子进程时立即返回
WUNTRACED 没有报告状态的进程时返回
wait和 waitpid 执行成功将返回终止的子进程的进程号,不成功返回-1。
getpid()系统调用语法:
#include sys/types.h
#include unistd.h
pid_t getpid(void);
pid_t getppid(void);
getpid返回当前进程的进程号,getppid 返回当前进程父进程的进程号
2) 与进程控制有关的系统调用说明
可以通过信号向一个进程发送消息以控制进程的行为。信号是由中断或异常事件引发的,如:键盘中断、定时器中断、非法内存引用等。信号的名字都以 SIG 开头,例如 SIGTERM、SIGHUP。可以使用 kill -l 命令查看系统当前的信号集合。
信号可在任何时间发生,接收信号的进程可以对接收到的信号采取3种处理
措施之一:
· 忽略这个信号
· 执行系统默认的处理
· 捕捉这个信号做自定义的处理
信号从产生到被处理所经过的过程:
产生(generate)-挂起(pending)-派送(deliver)-部署(disposition)或忽略(igore)
一个信号集合是一个C 语言的 sigset_t数据类型的对象,sigset_t数据类型定义在signal.h中。被一个进程忽略的所有信号的集合称为一个信号掩码(mask)。
从程序中向一个进程发送信号有两种方法:调用 shell的 kill命令,调用kill系统调用函数。kill能够发送除杀死一个进程(SIGKILL、SIGTERM、SIGQUIT) 之外的其他信号,例如键盘中断(Ctrl+C)信号SIGINT,进程暂停(Ctrl+Z)信号SIGTSTP 等
文档评论(0)