操作系统进程通信共享内存课程设计.pdf
《操作系统进程通信共享内存课程设计.pdf》由会员分享,可在线阅读,更多相关《操作系统进程通信共享内存课程设计.pdf(28页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、精品.河南城建学院 操作系统课程设计说明书 设计题目:进程通信 专 业:计算机科学与技术 指导教师:邵国金、郭猛、薛冰 班 级:学 号:姓 名:同 组 人:计算机科学与工程系 2013 年 1 月 10 日 精品.前 言 本设计是基于课程中学到的 UNIX 系统调用,使用操作系统环境是 Red Hat Linux 9,言语开发环境是 Linux 的 GNU C 或 C+。Linux 操作系统是一个向用户开放源码的免费的类UNIX 操作系统。它为在校学生学习操作系统课程提供了一个看得见摸得着的范例。对于学生正确理解,掌握操作系统的基本知识具有重要意义。鉴于此,本操作系统课程涉及的实验均在 Lin
2、ux 环境下进行。这就要求大家:(1)熟悉 Linux 的操作和开发环境;(2)具有 C 语言知识(Linux 操作系统大约 90%的源码是用 C 语言编写)。我们的设计和实验将在 Windows xp 环境下,基于虚拟机软件 VMWare 软件进行安装。学习计算机软件技术,特别是计算机操作系统技术,除了需要刻苦努力外,还需要掌握软件和操作系统的原理与设计技巧。如何学习和掌握操作系统技术的原理与实际技巧呢?除了听课和读书之外,最好的方法恐怕就是在实践中练习。例如,自己设计一个小型操作系统,多使用操作系统,多阅读和分析操作源代码等。但由于我们的条件和学时有限,在理论学习过程中没有给同学们提供更多
3、的实验机会。基于共享内存的进程通信,通过在两个进程间创建一块共享内存,将共享内存块分为两部分,标示位和数据域。通过实践让我们了解了什么是共享内存通信机制,实现了程序进程间的通信。积极通过合作,完成任务。精品.目录 一、系统开发环境.-4-二、设计目的.-5-三、设计题目及要求.-6-四、总体设计.-7-1、服务器功能.-7-2、客户端功能.-8-3、文件读取功能.-9-4、界面显示函数.-10-5、组成框图:.-10-6.共享内存分配.-10-7.总体流程图.-11-五、详细设计.-12-1.主函数.-12-2.菜单显示.-13-3.服务器端:.-13-4.客户端程序:.-15-5、部分函数介
4、绍.-17-六、调试与测试.-18-七、执行结果及分析.-19-八、源程序清单.-21-九、心得体会.-26-精品.十、参考文献.-28-一、系统开发环境 Windows Xp 系统、虚拟机上运行的 Red Hat Linux 9 系统运行环境。精品.二、设计目的 1、进一步了解什么是进程,以及创建进程的方式。2、实现 UNIX/LINUX 系统环境下的进程通信方式。3、熟练掌握 C/S 中的共享内存通信机制。4、开辟一个共享区,实现进程共享资源,互相通信。精品.三、设计题目及要求 利用 UNIX 系统提供的进程通信机制实现通信以及共享内存区的实现(1)共享存储区的创建,附接和断接 使用系统调
5、用 shmget(),shmat(),msgdt(),shmctl(),编制一长度为 1K 的消息发送和接收的程序。1)为了便于操作和观察结果,用一个程序作为“引子”,先后 fork()两个子进程,SERVER 和 CLIENT,进行通信。SERVER 和 CLIENT 也可分别为 2 个各自独立的程序。2)SERVER 端建立一个 Key 为 375 的共享区,并将第一个字节置为-1,作为数据空的标志,等待其他进程发来的消息。当该字节的值发生变化时,表示收到了信息,并进行处理。然后再次把它的值设为-1。如果遇到的值为 0,则视为结束信号,取消该队列,并退出 SERVER。SERVER 每接收
6、到一次数据后显示“(server)received”。3)CLIENT 端建立一个 Key 为 375 的共享区,当共享取得第一个字节为-1时,SERVER 端空闲,可发送请求。CLIENT 随即填入 9 到 0。期间等待 Server端的再次空闲。进行完这些操作后,CLIENT 退出。CLIENT 每发送一次数据后显示“(client)sent”。精品.4)父进程在 SERVER 和 CLIENT 均退出后结束。(2)功能扩展:在 sever 端创建一个服务函数,从而形成 C/S 通讯模式 要求 SERVER 每接收到一次数据后不仅仅显示“(server)received”,而是做一些其它事
7、情,比如读取或查询某个文件等。此功能可由设计者自己定义。四、总体设计 1.服务器功能 服务器共有四块共享内存,分别用 addr1,addr2,addr3,addr4 接收,其中 addr1 为整形指针,addr1,addr2,addr3 为结构体型指针,结构体的定义如下:Typedef strcut address Int mark;Char ch20;address;其中的 mark 成员用来作为标记为标示共享内存块的状态,-1 表示该内存块空闲,服务端可以发送服务请求,1,2,3 这分别表示服务器正在处理不同的服务请求,客精品.户端需等待。而字符数组成员 ch 则用来将各个客户端的文件中的
8、数据放入对应的共享内存块中,与服务器交换数据。而内存块之所以既能实现客户端与服务器的通信,又能相互之间交换数据,在于shmat 函数的返回值为 void*,可以将其转化为任意类型的指针变量,该函数调用如下:Addr1=(address*)shmat(shmid1,1024,0);Addr2=(address*)shmat(shmid2,1024,0);Addr3=(address*)shmat(shmid31024,0);该四块共享内存分别用于实现接受各个客户端的服务请求,处理客户端 1,客户端 2,客户端 3 的服务请求。各个共享内存模块的处理方法基本一致,即服务器处理完客户端的请求,将 a
9、ddr置为-1,即表示自己已空闲,可以接受服务请求;客户端发出服务请求后,等待服务器处理,一旦服务得到相应,将 addr 置为 1 或 2 或 3。2.客户端功能 可具体分成 3 个客户端,每个客户端均包含两块共享内存,第一块用于发送请求,其键值为各个客户端所知,第二块用于与服务器交互阶段的数据传递,其键值仅有本客户端与服务器知道。每块共享内存一包含两部分:1 用于表示共享内存块的状态的 addr1-mark,2 用于保存本客户端数据信息的数据域。其所在的进程完成自己的请求后,调用 exit(0)退出本进程。其分配共享内存块的系统的调用函数为:Shmid1=shmget(SHMKEY,1024
10、,0777|IPC_CREAT);Shmid2=shmget(SHMKEY,1024,0777|IPC_CREAT);Shmid3=shmget(SHMKEY,1024,0777|IPC_CREAT);至于内存共享的实现方式,与服务器相同。精品.3.文件读取功能 每个客户端均设置此功能,例如购买手机卡时,客户端 1 需检索自己的文件中是否存在该号码,如果已存在,则提示客户改号码已注册,需重新选择。该功能模块涉及到:1 读文件 2 查找 对于读文件,首先需打开文件,该函数定义一个文件型指针 fp,赋值操作为:Fp=fopen(“Info.txt”,”rw+”);打开文件成功后,利用 fgetc(
11、)函数从文件中一个一个字符的读取,当遇到n时,说明一个号码已经读取完毕。其函数使用如下:C=fgetc();While(!feof(fp)If(c=n)Numberi=0;I=-1;Else Numberi=c;C=fgetc();+I;对于本系统的检索功能,因为文件的读取操作较慢,很有可能使客户端进程阻塞,故设置一个 cellnumber()函数,使其预先将本文件中的所有号码全部读出,放入一个字符型二维数组中,这样当服务器需检索文件中号码时,直接从该二维数组中检索即可,大大提高了检索速度。检索所采用的方法是顺序查找法,可以达到预定的速度要求。精品.4.界面显示函数 即系统中的 display
12、()函数,其包含四个功能选项:1:购买手机卡;2:手机充值;3;办理网银;4:;退出本系统 前三项功能每一项对应一个客户进程,具体哪项进程由 choice 变量控制。5.组成框图:总体服务 3 个客户端 display()cellnumber()服务器端 6.共享内存分配 共享内存区 -1 由 SERVER 端开辟一块用来与各个客户端通信的共享内存区 共享内存区 精品.-1 客户 1 与服务器端共享内存区。共享内存区 客户 2 与服务器端共享内存区 共享内存区 客户 3 与服务器端共享内存区。7.总体流程图 Y N -1 -1 开始 i=fork()Cellnumber 文件信息 i=0 i=
13、fork()精品.Y N Y N 总体流程图 1 五、详细设计 1.主函数 int main()int choice,i;char ch520;display();do printf(请选择一项功能项:n);scanf(%d,&choice);fflush(stdin);while(choice!=1&choice!=2&choice!=3&choice!=4)printf(输入有误,请重新输入:n);scanf(%d,&choice);fflush(stdin);if(choice=4)return 0;else i=0 Client()Chioice结束 Serverr 服务器 Clien
14、t(1)Client(2)Client(3)精品.while(i=fork()=-1);if(!i)server(ch);else while(i=fork()=-1);if(!i)client(choice);wait(0);wait(0);while(choice!=4);return 0;2.菜单显示 void display()printf(-n);int i;for(i=1;imakr=-1;while(addr1-makr=-1);if(addr1-makr=1)c=fgetc(fp);int i=0;while(!feof(fp)if(c=n)numberi=0;i=-1;if(
15、!strcmp(number,addr1-ch)printf(号码已经占用,请重新选择一个:n);return;else numberi=c;c=fgetc(fp);+i;printf(手机号码已选定,请缴费 100 元:n);addr1-makr=-1;精品.while(addr1-makr=-1);if(addr1-makr=2)printf(交易完成,祝您愉快!n);shmctl(shmid1,IPC_RMID,0);if(*addr=2)shmid2=shmget(CLIENTTWO,1024,0777|IPC_CREAT);addr2=shmat(shmid2,0,0);printf
16、(请输入您的手机号码:n);addr2-makr=-1;while(addr2-makr=-1);if(addr2-makr=1)printf(Input Your Payroll:n);addr2-makr=-1;while(addr2-makr=-1);if(addr2-makr=2)printf(充值完成!n);shmctl(shmid2,IPC_RMID,0);if(*addr=3)shmid3=shmget(CLIENTTHREE,1024,0777|IPC_CREAT);addr3=shmat(shmid3,0,0);printf(请输入您的身份证号:n);addr3-makr=-
17、1;while(addr3-makr=-1);if(addr3-makr=1)printf(请输入您的手机号码:n);addr3-makr=-1;while(addr3-makr=-1);if(addr3-makr=2)printf(办理完成,祝您愉快!n);shmctl(shmid3,IPC_RMID,0);shmctl(shmid,IPC_RMID,0);4.客户端程序:void client(int choice)int shmid1,shmid2,shmid3;精品.int payroll;char ch120,ch250;shmid=shmget(SHMKEY,1024,0777|I
18、PC_CREAT);addr=shmat(shmid,0,0);while(*addr!=-1);if(choice=1)*addr=1;shmid1=shmget(CLIENTONE,1024,0777|IPC_CREAT);addr1=shmat(shmid1,0,0);while(addr1-makr!=-1);scanf(%s,addr1-ch);addr1-makr=1;while(addr1-makr!=-1);printf(已缴费 100 元!n);addr1-makr=2;if(choice=2)*addr=2;shmid2=shmget(CLIENTTWO,1024,0777
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 操作系统 进程 通信 共享 内存 课程设计
限制150内