网站大量收购闲置独家精品文档,联系QQ:2885784924

Linux实验报告三.docx

  1. 1、本文档共10页,可阅读全部内容。
  2. 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
Linux实验报告三课案

Linux 程序设计实验三 实验目的 对理论课中学习的进程有进一步的理解,练习使用ps命令常看进程; 深入理解多进程并发执行,学习使用fork+execl 函数来开启多进程,使用exit+wait 函数来结束进程; 进一步理解多进程间通信的信号方法,使用signal 函数来接受处理信号,使用kill 函数来发送信号; 了解多进程间管道通信,使用pipe 函数创建无命名管道,使用mkfifo 函数创建命名管道。 实验准备 在进行实验之前,需要学习和熟悉以下命令和函数: ps 命令 (输入man ps) fork 函数 (P398) exec 系列函数 (P396) wait 函数 (P400) signal 函数 (P406) kill 函数 (P408) pipe 函数 (P449) mkfifo 函数 (P457) read/write 函数 (P82) printf/fprintf /sprintf 函数 (P94) scanf/fscanf /sscanf 函数 (P96) 实验内容 练习使用ps 命令和不同参数来显示当前进程的不同信息,输入以下命令,将结果的前10行和后10行截图下来,分析所观察到输出结果有什么不同。 ps –ef ps aux ps -l 多进程并发执行实验(可参考P396-401):练习使用fork、exec和wait函数。编写一个程序,进行后台执行,完成以下任务: 生成子进程1和子进程2; 子进程1执行ls –l 命令,子进程2休眠,两个进程均输出显示自己的父进程号(使用getppid函数); 父进程阻塞,等待子进程结束。 在父进程中执行wait()等待子进程的结束: 使用ps 命令检查是否产生了僵尸进程;取消使父进程阻塞的函数,再使用ps 命令检查是否产生了僵尸进程。 取消父进程阻塞程序执行结果: 进程间信号实验(可参考P406-409): 单进程信号实验:使用signal函数编写一个程序并后台执行后,要求:1)循环输出句子“You need to press Ctrl+c twice !”,2)按下一次Ctrl+c 后,输出句子“You need to press Ctrl+c one more time !”,3)按下两次 Ctrl+c 后程序终止; 多进程信号实验:使用fork,kill和signal 函数编写一个程序进行后台执行,要求:1)使用fork函数创建一个子进程,2)父进程一直忽略Ctrl+c 信号,输出句子” Please wait 10 seconds to press Ctrl+c ! “,3)子进程在休眠10秒后,向父进程发送SIGUSR1信号,然后结束,4)父进程捕获信号后将Ctrl+c 的动作恢复为默认,输出句子”You can press Ctrl+c now !“,按下 Ctrl+c 结束程序。 进程间管道通信实验: pipe 无命名管道(可参考P450-451):使用fork 函数创建一个子进程,使用pipe函数创建一个无命名管道,父进程提示“Parent:”,将输入内容通过管道传递给子进程,子进程输出“Child:输入字符串,are you sure? y/n”,输入y,输出 “Command completed” 后结束;输入n,输出“OK, anyway.”后结束。 FIFO命名管道(可参考P465-466):使用mkfifo创建一个命名管道,编写两个程序,在第一个程序中输入的所有字符串,通过命名管道传递给第二个程序,第二个程序将字符串转换为大写形式后,将处理完的数据传递给第一个程序。 实验总结 1. 对理论课中学习的进程有了进一步的理解,学会了使用ps命令常看进程; 2. 理解了多进程并发执行,学习了使用fork+execl 函数来开启多进程和使用exit+wait 函数来结束进程; 3. 加深了对多进程间通信的信号方法的理解,学会了使用signal 函数来接受处理信号和使用kill 函数来发送信号; 4. 了解了多进程间管道通信,学会了使用pipe 函数创建无命名管道和使用mkfifo 函数创建命名管道。 深刻地觉得挺难的,花了好长时间都没调出来想要的结果,心好累。

文档评论(0)

jiayou10 + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

版权声明书
用户编号:8133070117000003

1亿VIP精品文档

相关文档