• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            Prayer

            在一般中尋求卓越
            posts - 1256, comments - 190, trackbacks - 0, articles - 0
              C++博客 :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理
            其他的不管,只是關注一下alarm的用法,設定了msgrcv超時。


            環境是redhat9
            當把發送緩沖中寫入大于8位數據時 可以成功發送但只能收到8位信息

            代碼如下
            //定義
            struct msgbuf  //消息結構
            {
                    long mtype;
                    char mtext[100];
            }msgbuf;
                                                                                            


            //創建消息隊列
            void  creatque()
            {
                                                                                                                                                           
                    static int msg_que_id=-1;
                    struct sigaction action;
                    /*檢查是否存在的要創建的消息隊列,如果存在到 就刪除它*/
                    msg_que_id=msgget(BOOKING_KEY,0);
                    if(msg_que_id!=-1){
                            if(msgctl(msg_que_id,IPC_RMID,0)==-1){
                                    perror("remove old message");
                                    exit(1);
                            }
                    }
                    /*創建消息隊列*/
                    msg_que_id=msgget(BOOKING_KEY,IPC_CREAT|0666);
                    if(msg_que_id==-1){
                            perror("creat new message list");
                            exit(1);
                    }
                    /*忽略其它一些參數*/
                    action.sa_handler=SIG_IGN;
                    action.sa_flags=0;
                    sigemptyset(&action.sa_mask);
                    sigaction(SIGINT,&action,NULL);
                    sigaction(SIGQUIT,&action,NULL);
                    sigaction(SIGHUP,&action,NULL);
            }

            //發消息
            void control(char *c)
            {
                    int send_len;
                    int msg_que_id=-1;
                    struct msgbuf send_msg;
                    memset(send_msg.mtext,'\0',sizeof(send_msg.mtext));
                    send_len=sizeof(long)+sizeof(int);
                    msg_que_id=msgget(BOOKING_KEY,0);
                    if(msg_que_id==-1){
                            perror("get message list id");
                            exit(1);
                    }
                                                                                            
                                                                                            
                    if(!strncasecmp(c,"lk",2)){/*連接狀態信號*/
                            send_msg.mtype=httpd_stoped;
                            sprintf(send_msg.mtext,"linking");
                            if(msgsnd(msg_que_id,&send_msg,send_len,0)&lt;0){
                                    perror("send message");
                                    exit(1);
                            }
                    }
            }

            //接收消息
            void *other_key(void *data)
            {
                    int msg_que_id=-1;
                    int rece_len,send_len;
                    struct msgbuf rece_msg;
                    memset(rece_msg.mtext,'\0',sizeof(rece_msg.mtext));
                    send_len=sizeof(long)+sizeof(int);
                    msg_que_id=msgget(BOOKING_KEY,0);
                    if(msg_que_id==-1){
                            perror("get message list id");
                            exit(1);
                    }
                    while(1){
                            /*定時器定時LKTIMEOUTs來接收30s一次的連接狀態信號,*/
                            /*如果時間到而沒有接收到信號則判斷接收方關閉了監視端,服務器將中斷此次連接*/
                                                                                                                                                   
                            alarm(35);
                            rece_len=msgrcv(msg_que_id,&rece_msg,sizeof(msgbuf)-sizeof(long),(int)httpd_stoped,0);
                            if(rece_len&lt;0){
                                    perror("receive message");
                                    exit(1);
                            }
                            if(!strcmp(rece_msg.mtext,"linking")){
                                  alarm(0);
                            }
                            else if(!strcmp(rece_msg.mtext,"q")){
                                     if(msgsnd(msg_que_id,&rece_msg,send_len,0)&lt;0){/*把取出的結束信息再寫回去(因為一條信息只能被取一次)*/
                                             perror("send message");               /*而取出一次只能結束一個進程*/
                                             exit(1);
                                     }
                                     exit(1);
                            }
                                                                                                                                                   
                                                                                                                                                   
            }
            }

            Feedback

            # re: 我創建的消息隊列為什么最大只能接收到8位信息--只關注alarm的用法  回復  更多評論   

            2009-04-30 16:14 by 半島刀客
            在msgsnd的長度參數,最好不要用sizeof()...,請直接用定長試試
            国产一区二区精品久久岳| 亚洲AV无码久久精品色欲| 久久99国产精品久久99| 中文精品久久久久国产网址 | 69久久夜色精品国产69| 国产精品99久久免费观看| 国产A级毛片久久久精品毛片| 久久婷婷五月综合色99啪ak| 亚洲综合久久夜AV | 久久精品国产亚洲AV高清热 | 精品久久久久久久中文字幕| 亚洲精品久久久www| 久久最新精品国产| 亚洲精品国精品久久99热一| 久久成人18免费网站| 无码日韩人妻精品久久蜜桃| 久久亚洲色一区二区三区| 国产精品久久久久久一区二区三区 | 色综合久久久久久久久五月| 久久成人永久免费播放| 99久久99久久| 久久久久久久久久久久中文字幕 | 国产69精品久久久久APP下载| 久久精品一本到99热免费| 亚洲日本va午夜中文字幕久久| 99久久777色| 99久久婷婷国产综合亚洲| 久久综合亚洲色HEZYO社区| 欧美性大战久久久久久| 国内精品久久久久久中文字幕| 国产精品视频久久久| 国产成人久久精品激情| 久久久精品国产sm调教网站| 青青草原精品99久久精品66 | 久久国产视频99电影| 蜜桃麻豆www久久| 青青青青久久精品国产| 91精品免费久久久久久久久| 99久久综合国产精品二区| 国内精品久久久久久中文字幕| 国产精品无码久久四虎|