• <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久久超碰成人精品网站| 999久久久无码国产精品| 久久精品无码一区二区三区日韩| 国产精品免费久久久久久久久| 国内精品久久久久国产盗摄| 久久久SS麻豆欧美国产日韩| 久久亚洲欧美国产精品| 人人狠狠综合久久亚洲高清| 久久久久99精品成人片直播| 精品国产青草久久久久福利 | 日韩欧美亚洲国产精品字幕久久久 | 久久婷婷色综合一区二区| 亚洲AV无一区二区三区久久 | 久久亚洲国产成人影院网站| 欧美熟妇另类久久久久久不卡| 久久最新免费视频| 日本精品久久久久中文字幕8| 久久精品国产色蜜蜜麻豆| 久久无码人妻精品一区二区三区| 人妻久久久一区二区三区| 亚洲国产日韩欧美久久| 99久久精品国产一区二区蜜芽| 久久天天躁狠狠躁夜夜avapp| 要久久爱在线免费观看| 久久久久无码国产精品不卡| 国内精品伊人久久久久| 久久狠狠高潮亚洲精品 | 国产A级毛片久久久精品毛片| 97精品伊人久久大香线蕉app| 亚洲国产精品久久久天堂| 国内高清久久久久久| 久久久午夜精品| 久久久亚洲裙底偷窥综合| 亚洲午夜无码久久久久小说| 欧美精品丝袜久久久中文字幕 | 无码任你躁久久久久久| 久久伊人色| 日本高清无卡码一区二区久久 | 久久亚洲精精品中文字幕| 欧洲精品久久久av无码电影| 色欲综合久久中文字幕网|