⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 linux环境进程间通信(三):消息队列.htm

📁 本资源中含有有关LINUX进程通信的一些文章
💻 HTM
📖 第 1 页 / 共 4 页
字号:
int reval;
sleep(1);//只是为了后面输出时间的方便
reval=msgctl(msgid,IPC_STAT,&msg_info);
if(reval==-1)
{
    printf("get msg info error\n");
    return;
}
printf("\n");
printf("current number of bytes on queue is %d\n",msg_info.msg_cbytes);
printf("number of messages in queue is %d\n",msg_info.msg_qnum);
printf("max number of bytes on queue is %d\n",msg_info.msg_qbytes);
//每个消息队列的容量(字节数)都有限制MSGMNB,值的大小因系统而异。在创建新的消息队列时,//msg_qbytes的缺省值就是MSGMNB
printf("pid of last msgsnd is %d\n",msg_info.msg_lspid);
printf("pid of last msgrcv is %d\n",msg_info.msg_lrpid);
printf("last msgsnd time is %s", ctime(&(msg_info.msg_stime)));
printf("last msgrcv time is %s", ctime(&(msg_info.msg_rtime)));
printf("last change time is %s", ctime(&(msg_info.msg_ctime)));
printf("msg uid is %d\n",msg_info.msg_perm.uid);
printf("msg gid is %d\n",msg_info.msg_perm.gid);
}
</CODE>
</PRE></TD></TR></TBODY></TABLE>程序输出结果见<A 
            href="http://www-900.ibm.com/developerWorks/cn/linux/l-ipc/part3/index.shtml#listing3">附录 
            3</A>。<BR>
            <P><A id=5 name=5><SPAN 
            class=atitle2>小结:</SPAN></A><BR>消息队列与管道以及有名管道相比,具有更大的灵活性,首先,它提供有格式字节流,有利于减少开发人员的工作量;其次,消息具有类型,在实际应用中,可作为优先级使用。这两点是管道以及有名管道所不能比的。同样,消息队列可以在几个进程间复用,而不管这几个进程是否具有亲缘关系,这一点与有名管道很相似;但消息队列是随内核持续的,与有名管道(随进程持续)相比,生命力更强,应用空间更大。</P>
            <P><B><A name=listing1>附录 
            1</A>:</B>在参考文献[1]中,给出了IPC随进程持续、随内核持续以及随文件系统持续的定义:</P>
            <OL>
              <LI>随进程持续:IPC一直存在到打开IPC对象的最后一个进程关闭该对象为止。如管道和有名管道; 
              <LI>随内核持续:IPC一直持续到内核重新自举或者显示删除该对象为止。如消息队列、信号灯以及共享内存等; 
              <LI>随文件系统持续:IPC一直持续到显示删除该对象为止。 </LI></OL><BR>
            <P><B><A name=listing2>附录 
            2</A>:</B><BR>结构msg_queue用来描述消息队列头,存在于系统空间:</P>
            <TABLE cellSpacing=0 cellPadding=5 width="100%" bgColor=#cccccc 
            border=1>
              <TBODY>
              <TR>
                <TD><PRE><CODE>struct msg_queue {
    struct kern_ipc_perm q_perm;
    time_t q_stime;         /* last msgsnd time */
    time_t q_rtime;         /* last msgrcv time */
    time_t q_ctime;         /* last change time */
    unsigned long q_cbytes;     /* current number of bytes on queue */
    unsigned long q_qnum;       /* number of messages in queue */
    unsigned long q_qbytes;     /* max number of bytes on queue */
    pid_t q_lspid;          /* pid of last msgsnd */
    pid_t q_lrpid;          /* last receive pid */
    struct list_head q_messages;
    struct list_head q_receivers;
    struct list_head q_senders;
};
</CODE>
</PRE></TD></TR></TBODY></TABLE><BR>
            <P>结构msqid_ds用来设置或返回消息队列的信息,存在于用户空间;</P>
            <TABLE cellSpacing=0 cellPadding=5 width="100%" bgColor=#cccccc 
            border=1>
              <TBODY>
              <TR>
                <TD><PRE><CODE>struct msqid_ds {
    struct ipc_perm msg_perm;
    struct msg *msg_first;      /* first message on queue,unused  */
    struct msg *msg_last;       /* last message in queue,unused */
    __kernel_time_t msg_stime;  /* last msgsnd time */
    __kernel_time_t msg_rtime;  /* last msgrcv time */
    __kernel_time_t msg_ctime;  /* last change time */
    unsigned long  msg_lcbytes; /* Reuse junk fields for 32 bit */
    unsigned long  msg_lqbytes; /* ditto */
    unsigned short msg_cbytes;  /* current number of bytes on queue */
    unsigned short msg_qnum;    /* number of messages in queue */
    unsigned short msg_qbytes;  /* max number of bytes on queue */
    __kernel_ipc_pid_t msg_lspid;   /* pid of last msgsnd */
    __kernel_ipc_pid_t msg_lrpid;   /* last receive pid */
};
</CODE>
</PRE></TD></TR></TBODY></TABLE>//可以看出上述两个结构很相似。<BR>
            <P><B><A name=listing3>附录 3</A>:</B>消息队列实例输出结果:</P>
            <TABLE cellSpacing=0 cellPadding=5 width="100%" bgColor=#cccccc 
            border=1>
              <TBODY>
              <TR>
                <TD><PRE><CODE>current number of bytes on queue is 0
number of messages in queue is 0
max number of bytes on queue is 16384
pid of last msgsnd is 0
pid of last msgrcv is 0
last msgsnd time is Thu Jan  1 08:00:00 1970
last msgrcv time is Thu Jan  1 08:00:00 1970
last change time is Sun Dec 29 18:28:20 2002
msg uid is 0
msg gid is 0
//上面刚刚创建一个新消息队列时的输出
current number of bytes on queue is 1
number of messages in queue is 1
max number of bytes on queue is 16384
pid of last msgsnd is 2510
pid of last msgrcv is 0
last msgsnd time is Sun Dec 29 18:28:21 2002
last msgrcv time is Thu Jan  1 08:00:00 1970
last change time is Sun Dec 29 18:28:20 2002
msg uid is 0
msg gid is 0
read from msg queue 1 bytes
//实际读出的字节数
current number of bytes on queue is 0
number of messages in queue is 0
max number of bytes on queue is 16384   //每个消息队列最大容量(字节数)
pid of last msgsnd is 2510
pid of last msgrcv is 2510
last msgsnd time is Sun Dec 29 18:28:21 2002
last msgrcv time is Sun Dec 29 18:28:22 2002
last change time is Sun Dec 29 18:28:20 2002
msg uid is 0
msg gid is 0
current number of bytes on queue is 0
number of messages in queue is 0
max number of bytes on queue is 16388   //可看出超级用户可修改消息队列最大容量
pid of last msgsnd is 2510
pid of last msgrcv is 2510  //对操作消息队列进程的跟踪
last msgsnd time is Sun Dec 29 18:28:21 2002
last msgrcv time is Sun Dec 29 18:28:22 2002
last change time is Sun Dec 29 18:28:23 2002    //msgctl()调用对msg_ctime有影响
msg uid is 8
msg gid is 8
</CODE>
</PRE></TD></TR></TBODY></TABLE><BR><!-- RESOURCES-->
            <P><A id=resources name=resources><SPAN 
            class=atitle2>参考文献:</SPAN></A></P>
            <UL>
              <LI>UNIX网络编程第二卷:进程间通信,作者:W.Richard 
              Stevens,译者:杨继张,清华大学出版社。对POSIX以及系统V消息队列都有阐述,对Linux环境下的程序开发有极大的启发意义。 

              <LI>linux内核源代码情景分析(上),毛德操、胡希明著,浙江大学出版社,给出了系统V消息队列相关的源代码分析。 
              <LI><A href="http://www.fanqiang.com/a4/b2/20010508/113315.html" 
              target=_blank>http://www.fanqiang.com/a4/b2/20010508/113315.html</A>,主要阐述linux下对文件的操作,详细介绍了对文件的存取权限位,对IPC对象的存取权限同样具有很好的借鉴意义。 

              <LI>msgget、msgsnd、msgrcv、msgctl手册 </LI></UL><BR><!-- AUTHOR BIOS--><!-- Make author heading singular or plural as needed-->
            <TABLE cellSpacing=0 cellPadding=0 width="100%" border=0>
              <TBODY>
              <TR>
                <TD><A id=author1 name=author1><SPAN 
                  class=atitle2>关于作者:</SPAN></A> <BR>郑彦兴,国防科大攻读博士学位。联系方式: <A 
                  href="mailto:mlinux@163.com">mlinux@163.com</A></TD></TR></TBODY></TABLE><BR></TD></TR>
        <TR vAlign=center align=right>
          <TD vAlign=bottom bgColor=#ffffff><INPUT style="COLOR: #000000; BACKGROUND-COLOR: #ffffff" onclick=window.close() type=button value=关闭窗口><BR><BR></TD></TR></TBODY></TABLE>
      <TABLE cellSpacing=0 cellPadding=0 width="100%" align=center border=0>
        <TBODY>
        <TR>
          <TD vAlign=center align=middle>
            <HR align=center width="100%" color=#cccccc noShade SIZE=1>
            <FONT color=red><B>特别声明:</B></FONT>文章版权归原作者所有, 未经允许请勿转载, 如有任何问题请<A 
            href="mailto:webmaster@vczx.com">联系我们</A>.
            <P></P></TD></TR>
        <TR class=left_tdbgall align=right>
          <TD colSpan=2 height=24>【字体:<A class=top_UserLogin 
            href="javascript:fontZoomA();">小</A> <A class=top_UserLogin 
            href="javascript:fontZoomB();">大</A>】【<A 
            href="http://study.feloo.com/computer/Comment.asp?ArticleID=39162" 
            target=_blank>发表评论</A>】【<A 
            href="http://study.feloo.com/User/User_Favorite.asp?Action=Add&amp;ChannelID=25&amp;InfoID=39162" 
            target=_blank>加入收藏</A>】【<A 
            href="http://study.feloo.com/computer/SendMail.asp?ArticleID=39162" 
            target=_blank>告诉好友</A>】【<A 
            href="http://study.feloo.com/computer/Print.asp?ArticleID=39162" 
            target=_blank>打印此文</A>】【<A 
            href="javascript:window.close();">关闭窗口</A>】 </TD></TR>
        <TR>
          <TD class=left_tdbgall align=right colSpan=2 
            height=24>电脑文章录入:admin&nbsp;&nbsp;&nbsp;&nbsp;责任编辑:admin&nbsp; 
</TD></TR><!--文章内容下部广告代码开始-->
        <TR>
          <TD align=middle colSpan=2>
            <SCRIPT src="Linux环境进程间通信(三):消息队列.files/wen-bot.js"></SCRIPT>
          </TD></TR><!--文章同容下部广告代码结束-->
        <TR>
          <TD class=left_tdbgall align=right colSpan=2 height=24><STRONG><FONT 
            color=#ff0000>百度搜索:<A 
            href="http://www.baidu.com/baidu?tn=study888&amp;word=Linux环境进程间通信(三):消息队列" 
            target=_blank>Linux环境进程间通信(三):消息队列</FONT></A></STRONG>
            <SCRIPT src=""></SCRIPT>
          </TD></TR>
        <TR>
          <TD width=5></TD>
          <TD width=787>
            <LI>上一篇电脑文章: <A 
            title="电脑文章标题:Linux环境进程间通信(二):信号(下)&#13;&#10;作&nbsp;&nbsp;&nbsp;&nbsp;者:未知&#13;&#10;更新时间:2005-6-9 18:12:30" 
            href="http://study.feloo.com/computer/pro/vc/system/200506/39161.html">Linux环境进程间通信(二):信号(下)</A><BR>
            <LI>下一篇电脑文章: <A 
            title="电脑文章标题:Linux环境进程间通信(四):信号灯&#13;&#10;作&nbsp;&nbsp;&nbsp;&nbsp;者:未知&#13;&#10;更新时间:2005-6-9 18:12:35" 
            href="http://study.feloo.com/computer/pro/vc/system/200506/39163.html">Linux环境进程间通信(四):信号灯</A></LI></TD></TR><!--文章内容下部广告代码开始-->
        <TR>
          <TD align=middle colSpan=2>
            <SCRIPT src="Linux环境进程间通信(三):消息队列.files/wen-bot-2.js"></SCRIPT>
          </TD></TR><!--文章同容下部广告代码结束--></TBODY></TABLE><!--网页中部左栏文章内容代码结束-->
      <TABLE cellSpacing=0 cellPadding=0 width="100%" border=0>
        <TBODY>
        <TR>
          <TD align=middle height=20></TD></TR></TBODY></TABLE></TD>
    <TD style="BORDER-LEFT: #a7a9a7 1px solid" vAlign=top width=180 
    bgColor=#f8f8f8><!--网页中部右栏代码开始-->
      <TABLE style="WORD-BREAK: break-all" cellSpacing=0 cellPadding=0 
      width="100%" border=0>
        <TBODY>
        <TR>
          <TD class=left_title><IMG height=28 
            src="Linux环境进程间通信(三):消息队列.files/ad_search.gif" width=174></TD></TR>
        <TR>
          <TD align=middle>
            <SCRIPT 
            src="Linux环境进程间通信(三):消息队列.files/ShowSearchForm_wen.js"></SCRIPT>
          </TD></TR>
        <TR>
          <TD align=middle>
            <SCRIPT src="Linux环境进程间通信(三):消息队列.files/right-1.js"></SCRIPT>
          </TD></TR>
        <TR>
          <TD class=left_title><IMG height=28 
            src="Linux环境进程间通信(三):消息队列.files/ad_ztlm.gif" width=174></TD></TR>
        <TR>
          <TD class=left_tdbg1>
            <SCRIPT language=javascript 
            src="Linux环境进程间通信(三):消息队列.files/com-tjlm.js"></SCRIPT>
          </TD></TR>
        <TR>
          <TD class=left_tdbg2></TD></TR>
        <TR>
          <TD class=left_title><A class=class 
            href="http://study.feloo.com/computer/ShowHot.asp"><IMG height=28 
            src="Linux环境进程间通信(三):消息队列.files/ad_zxrmwz.gif" width=174 
            border=0></A></TD></TR>
        <TR>

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -