• <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()...,請直接用定長試試
            色欲综合久久躁天天躁| 久久久久免费精品国产| 色综合久久久久久久久五月| 一97日本道伊人久久综合影院| 久久青青色综合| 中文国产成人精品久久不卡| 青草国产精品久久久久久| 91久久精品91久久性色| 精品久久久久久99人妻| 色天使久久综合网天天| 狠狠色伊人久久精品综合网| 97超级碰碰碰碰久久久久| 日本久久中文字幕| 亚洲国产成人久久综合区| 亚洲人成无码久久电影网站| 一级做a爰片久久毛片免费陪| 久久精品二区| 国产午夜久久影院| 影音先锋女人AV鲁色资源网久久 | 亚洲级αV无码毛片久久精品| 欧美亚洲国产精品久久高清| 久久成人国产精品二三区| 欧美精品一区二区精品久久| 久久国产视频99电影| 色婷婷久久综合中文久久一本| 成人久久免费网站| 国产成人久久精品一区二区三区| 亚洲精品国产综合久久一线| 综合网日日天干夜夜久久 | 欧洲国产伦久久久久久久| 欧美激情一区二区久久久| 久久99精品久久久久久久不卡| 国产A级毛片久久久精品毛片| 久久人人爽人人爽人人AV| 国产精品久久久天天影视香蕉| 亚洲а∨天堂久久精品9966| WWW婷婷AV久久久影片| 亚洲精品国产综合久久一线| 精品一区二区久久| 久久精品综合网| 久久精品不卡|