Linux进程控制与进程间通信.pptVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
Linux进程控制与进程间通信

* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * 消息队列 第7章 第*页 消息队列的创建 系统调用msgget #include sys/types.h #include sys/ipc.h #include sys/msg.h int msgget(key_t key, int flags); 在内核中创建新消息队列或获取已存在消息队列的ID,发送/接收消息的系统调用使用qid(qid是内核中msqid_ds数组的下标) 创建消息队列 qid = msgget(462101, IPC_CREAT | 0666); 取得一个已存在的消息队列 qid = msgget(462101, 0); 第7章 第*页 消息队列的系统数据结构 内核中每个消息队列对应一个msqid_ds结构 struct msqid_ds { /* msg ID data structure */ struct ipc_perm msg_perm; /* operation permission struct */ struct msg *msg_first; /* ptr to first message on q*/ struct msg *msg_last; /* ptr to last message on q*/ ushort msg_cbytes; /* current # bytes on q */ unsigned short msg_qnum; /* # of messages on q */ unsigned short msg_qbytes; /* max # of bytes on q */ ushort msg_lspid; /* pid of last msgsnd */ ushort msg_lrpid; /* pid of last msgrcv */ time_t msg_stime; /* last msgsnd time */ time_t msg_rtime; /* last msgrcv time */ time_t msg_ctime; /* last change time */ }; 第7章 第*页 消息队列的状态和删除 系统调用msgctl int msgctl(int qid, int cmd, struct msqid_ds *sbuf); 将消息队列从内核中删除 msgctl(qid, IPC_RMID, 0); 查看消息队列当前状态 struct msqid_ds st; msgctl(qid, IPC_STAT, st); 获取内核消息队列的系统数据结构,包括消息队列的总容量,当前队列有多少个消息,消息共多少个字节,等等 第7章 第*页 发送消息msgsnd int msgsnd(int qid, struct msgbuf *buf, int nbytes, int flags); 返回值为0(成功),或者为-1(失败) buf是一个指针,指定一个缓冲区 struct msgbuf { long mtype; /* mtype必须大于零 */ char mtext[1]; }; 前4字节存放mtype,从第5字节开始nbytes字节的数据作为消息的有效内容(nbytes没有将mtype的4字节计在内) flags flags=0时,阻塞方式:如果队列满则等待直到能够把消息发送出去为止。除非有意外发生(如:消息队列被删掉,有信号到达) flags=IPC_NOWAIT时,非阻塞方式:如果队列满,则msgsnd马上返回-1,不等待,errno被设为EAGAIN 第7章 第*页 接收消息msgrcv int msgrcv(int qid, struct msgbuf *buf, int nbytes, long mtype, int flags); 返回值为-1

文档评论(0)

xcs88858 + 关注
实名认证
文档贡献者

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

版权声明书
用户编号:8130065136000003

1亿VIP精品文档

相关文档