资源描述:
《进程实验-进程间通信(管道、消息、共享内存、软中断)》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库。
1、6进程实验3Linux进程间通信一、软中断信号的处理,实现同一用户的各进程之间的通信。l相关的系统调用nkill(pid,sig):发送信号nsignal(sig,func):指定进程对信号sig的处理行为是调用函数func。l程序清单#include#include#includevoidwaiting();voidstop();intwait_mark;main(){intp1,p2;while((p1=fork())==-1);if(p1>0){while((p2=fork())==-1
2、);if(p2>0){printf("parent");/*父进程在此完成某个操作、或接收到用户从键盘输入的特殊按键命令后发出下面的信号。这里省略。*/kill(p1,16);kill(p2,17);wait(0);wait(0);printf("parentprocessidkilled!");exit(0);}else/*p2==0*/{printf("p2");wait_mark=1;signal(17,stop);waiting();printf("childprocess2iskilledbyparent!");exit(0
3、);}}else/*p1==0*/{66printf("p1");wait_mark=1;signal(16,stop);waiting();printf("childprocess1iskelledbyparent!");exit(0);}}voidwaiting(){while(wait_mark!=0);}voidstop(){wait_mark=0;}l输入并运行此程序,分析程序的运行结果。一、消息的创建、发送和接收l多个进程通过访问一个公共的消息队列来交换信息l消息队列:即消息的一个链表l任何进程都可以向消息队列中发送消息(消息类型
4、及正文),其它进程都可以从消息队列中根据类型获取相应的消息l相关的系统调用头文件:#includeu打开或创建消息队列:intmsgget(key_tkey,intmsgflg);lkey:消息队列的键nIPC_PRIVATE:创建一个私有的消息队列n其它:可被多个进程使用的消息队列lmsgflg:设置操作类型及访问权限IPC_CREAT/IPC_EXCLu获得或设置消息队列属性:intmsgctl(intmsgid,intcmd,structmsqid_ds*data);u发送消息:intmsgsnd(intmsgid,con
5、stvoid*msgp,size_tmsgsize,intflags);l参数nmsgid:消息队列标识符idnmsgp:指针,用户自定义缓冲区,可定义成结构体类型,包含两项longmtype;代表消息类型charmtext[MTEXTSIZE];消息正文nmsgsize:要发送消息正文的长度nmflags:标志,若设置IPC_NOWAIT则不等待消息发出就返回l返回值:成功返回0,错误返回-1(置errno)u接收消息intmsgrcv(intmsgid,void*msgp,size_tmtexsize,longmsgtype,intflags);
6、66l参数:与msgsnd类似umsgtypel>0:只接收指定类型消息的第一个l==0:不管什么消息类型都读取队列中第一个数据l<0:接收等于或小于其绝对值的最低类型的第一个,如有5、6、17三类,若为-6,则获取类型5的。l返回值u成功:返回消息正文字节数u错误:返回-1(置errno)l程序清单#include#include#include#include#defineMSGKEY75structmsgform{longmtype;charmsgtext[
7、1030];}msg;intmsgqid,i;voidCLIENT(){inti;charstring_i[5];msgqid=msgget(MSGKEY,0777);for(i=10;i>=1;i--){msg.mtype=i;printf("(client)sent");sprintf(msg.msgtext,"thecontentofmessage");sprintf(string_i,"%d",i);strcat(msg.msgtext,string_i);strcat(msg.msgtext,"");msgsnd(msgqid,&m
8、sg,1030,0);}exit(0);}voidSERVER(){msgqid=msgget(MSGKEY