- 1、本文档共5页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
实验五 Linux进程间通信05010501.pdf
实验五 Linux 进程间通信
【实验目的】
掌握管道通信程序的基本编写方法
掌握信号通信程序的基本编写方法
掌握信号量通信程序的编写方法
掌握共享内存通信程序的编写方法
掌握消息队列通信程序的编写方法
【实验学时】
建议 2 学时
【实验内容】
1、了解什么是管道,熟悉LINUX 支持的管道通信方式
2 、了解什么是信号,熟悉LINUX 系统中进程之间软中断通信的基本原理。
【实验原理】
见教材第四章
【实验要求】
调试验证程序,并提交实验报告。
【实验步骤】
(1) 打开目录4-1-0-ipc ,将其中的produce-core-dump.c 文件编译生成可执行文件。输入:Ulimit
–c 1024 命令,使程序出错后可生成 core dump 文件,运行 produce-core-dump 的可执行文件,
观察结果。
(2) 打开目录 4-2-1-ipc-pipe 和 4-2-2-ipc-standard-pipe ,编译并运行后,观察运行结果。打开
目录4-2-3-ipc-fifo-pipe ,在PC 机 Fedora 中编译并运行后,观察运行结果。将程序交叉编译
后,在开发板的控制终端与 PC 机 Fedora 的控制终端中分别运行读写管道程序,观察运行结
果。
(3) 打 开 目 录 4-3-1-ipc-kill-raise 、 4-3-2-ipc-alarm-pause 、 4-3-3-1-ipc-signal 、
4-3-3-2-ipc-signalaction 和 4-3-3-3-ipc-signaleset ,编译并运行程序,观察运行结果。
(4) 打开目录 4-4-ipc-sem 编译并运行程序,观察运行结果。
(5) 打开目录 4-5-ipc-shmem 编译并运行程序,观察运行结果。
(6) 打开目录 4-6-ipc-msg 编译并运行程序,观察运行结果。
(7) 打开目录 4-7-1-ipc 编译并运行程序,观察运行结果。
(8) 打开目录 4-7-2-ipc 编译并运行程序,观察运行结果。
(9) 将上面程序交叉编译后,在开发板上运行,观察运行结果。
【思考题】
思考题 1. 管道通信
编制一段程序,实现进程的管道通信。使用 pipe()建立一条管道线。两个子进程 p1 和 p2 分
别向管道各写一句话:
Child 1 is sending message!
Child 2 is sending message!
而父进程则从管道中读出来自于两个子进程的信息,显示在屏幕上。
参考程序
# includeunistd.h
# includesignal.h
# includestdio.h
int pid1,pid2;
main()
{
int fd[2];
char OutPipe[100],InPipe[100];
pipe(fd);
while((pid1=fork())== -1);
if(pid1 == 0)
{
lockf(fd[1],1,0);
sprintf(OutPipe, child 1 process is sending message!);
write(fd[1],OutPipe,50);
sleep(5);
lockf(fd[1],0,0);
exit(0);
}
else{
while((pid2=fork())== -1);
if(pid2 == 0)
{
lockf(fd[1],1,0);
sprintf(OutPipe, child 2 process is sending message!);
write(fd[1],OutPipe,50);
sleep(5);
lockf(fd[1],0,0);
exit(0);
}
else{
wait(0);
read(fd[0],InPipe,50);
文档评论(0)