• <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>

            冰果

            技術群:26678700     
            交流QQ: 704839634
            合作: 1) 可兼職遠程辦公開發; 2) 有一套Go+Python開發的行業短信云平臺可合作;3)目前正在開發物聯網、大數據平臺。

            recv行為描述錯了

                  上一篇說recv()問題,我描述錯誤了,很多網友一眼就發現了,而且指了出來,十分感謝。
                  更難得的是第4位回復者,不但發現我的錯誤,而且能推測出我實現中是怎么做的,這種分析能力,一方面體現出你一定的實際開發經驗,另一方面也體現了你對需求理解能力一定很不錯。
                  正如第4位回復者所說,為了能方便使用經典的同步-阻塞模式,一般會采用select()-recv()搭配調用,還會對recv()進行封裝.
                  ssize_t recv(int s, void *buf, size_t len, int flags);
                  其行為是有數據就返回,返回實際收到長度: [1,  len], 或者正常關閉返回0, 或者出現錯誤返回-1.
                  因為我們應用常常喜歡使用包頭固定長度 + 包體變長模式來處理,我們是知道我們一定要多長才能正確得到一個協議包的,所以收滿一個固定包頭長度才能處理,得到包體長度值,再用這個長度去接收包體。
                  因此做一個封裝是常見現象:

            bool Read(int sock, char * buffer, size_t len)
            {
                    int ret = 0;
                    while( len > 0 ) {
                            ret = recv( sock, buffer, len, 0 );
                            if( 0 >= ret ) {
                                    return false;
                            }
                            buffer += ret;
                            len -= ret;
                    }
                    return true;
            }
                  這個其實也不完全是現實中的,現實中可能返回int, 可能里面有日志處理,可能直接有close()。
                  總之,這么封裝之后,你調用Read( buf, 31), 如果服務器只返回4個字節,既不關閉也不異常,那結果就是一直等待數據到來。
                  If no messages are available at the socket, the receive calls wait for a message to  arrive, unless the socket is non-blocking。
                  歡迎多討論,歡迎多發現問題。
                  

            posted on 2012-03-09 21:24 冰果 閱讀(1367) 評論(3)  編輯 收藏 引用

            評論

            # re: recv行為描述錯了 2012-03-10 15:36 春秋十二月

            這個Read函數,前提是socket是blocking的,如果是no-blocking的話,就要搭配select了  回復  更多評論   

            # re: recv行為描述錯了 2012-05-09 14:18 天下

            你要這樣用的話,一個參數就可以了,何必這么麻煩
            在阻塞的方式下:
            注意recv的最后一個參數:MSG_WAITALL  回復  更多評論   

            # re: recv行為描述錯了[未登錄] 2012-05-10 11:14 春秋十二月

            @天下
            不帶超時用MSG_WAITALL是不錯的選擇 唯一的問題可能是底層支持及跨平臺與否   回復  更多評論   

                                                        
            国产成人精品白浆久久69| 综合久久一区二区三区| 国产精品久久久久9999高清| 97久久久久人妻精品专区| 青青草国产精品久久久久| 欧美精品福利视频一区二区三区久久久精品| 国内精品久久久久影院网站| 久久久亚洲裙底偷窥综合| avtt天堂网久久精品| 色天使久久综合网天天| 999久久久无码国产精品| 香港aa三级久久三级老师2021国产三级精品三级在 | 久久精品国产亚洲Aⅴ香蕉| 欧美亚洲国产精品久久高清 | 久久午夜无码鲁丝片秋霞| 99久久无码一区人妻a黑| 亚洲&#228;v永久无码精品天堂久久| 亚洲精品乱码久久久久久蜜桃不卡| 精品午夜久久福利大片| 久久久久久综合网天天| 久久国产福利免费| 亚洲国产精品人久久| 久久狠狠高潮亚洲精品| 久久久亚洲裙底偷窥综合| 久久人人爽人人爽人人片AV麻豆 | 亚洲人成无码久久电影网站| 久久91精品国产91久久麻豆| 久久精品水蜜桃av综合天堂| 久久久久亚洲av成人网人人软件 | 亚洲成av人片不卡无码久久| 国产高清美女一级a毛片久久w| 久久久精品人妻一区二区三区蜜桃| 综合久久一区二区三区 | 久久综合久久综合久久| 99久久人妻无码精品系列蜜桃| 久久人人爽人人爽人人片AV不| 国产精品99久久久精品无码| 伊人久久精品影院| 久久人人添人人爽添人人片牛牛| 久久精品桃花综合| 人妻久久久一区二区三区|