• <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()...,請直接用定長試試
            精品久久久久久国产免费了| 久久热这里只有精品在线观看| 久久综合狠狠综合久久综合88| 久久久精品人妻一区二区三区蜜桃| 7777精品久久久大香线蕉| 欧美亚洲色综久久精品国产| 天天综合久久久网| 久久久久久曰本AV免费免费| 久久91亚洲人成电影网站| 亚洲精品无码久久毛片| 69SEX久久精品国产麻豆| 人人狠狠综合久久亚洲| 精品少妇人妻av无码久久| 久久久久国产视频电影| 久久精品亚洲一区二区三区浴池 | 99re这里只有精品热久久| 美女写真久久影院| 三级三级久久三级久久| 亚洲午夜久久影院| 久久国产精品一国产精品金尊| 三级片免费观看久久| 久久精品免费观看| 日韩精品久久无码中文字幕| 亚洲七七久久精品中文国产| 丁香五月综合久久激情| 久久青青草原国产精品免费 | 人妻丰满?V无码久久不卡| 91精品婷婷国产综合久久 | 精品久久久久久久中文字幕| 久久精品国产99久久久| 伊人久久大香线蕉av一区| 亚洲美日韩Av中文字幕无码久久久妻妇| 999久久久免费精品国产| 久久精品国产99久久久| 久久久久久久波多野结衣高潮| 亚洲&#228;v永久无码精品天堂久久 | 一本久久a久久精品亚洲| 久久精品国产欧美日韩99热| 少妇被又大又粗又爽毛片久久黑人 | 久久99热这里只有精品国产| 久久99精品国产99久久6|