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

            huyutian

            他強(qiáng)由他強(qiáng),清風(fēng)拂山崗;他橫由他橫,明月照大江。他自狠來(lái)他自惡,我自一口真氣足

              C++博客 :: 首頁(yè) :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理 ::
              20 隨筆 :: 47 文章 :: 22 評(píng)論 :: 0 Trackbacks
            對(duì)于socket編程一直有一種誤解:socket的阻塞連接下應(yīng)該調(diào)用send/recv來(lái)發(fā)送和接收數(shù)據(jù),而無(wú)阻塞連接下應(yīng)該用WSASend/WSARecv函數(shù)來(lái)發(fā)送和接收數(shù)據(jù)。其實(shí)socket工作模式與調(diào)用哪個(gè)收發(fā)函數(shù)沒(méi)有任何關(guān)系,自己寫(xiě)段簡(jiǎn)單的代碼測(cè)試下就知道了。無(wú)阻塞模式下,send/recv都是立即返回的。并不會(huì)等待發(fā)送或接收完成才返回。測(cè)試還發(fā)現(xiàn)選擇模式下無(wú)阻塞連接,調(diào)用connect函數(shù)會(huì)立即返回,隨后調(diào)用select,在連接建立時(shí)會(huì)設(shè)置fdWrite。
            SOCKET s = ::socket(AF_INET, SOCK_STREAM, IPPROTO_TCP);
            if (s == INVALID_SOCKET)
            {
                
            return -1;
            }


            // Set the connection to non-blocking mode
            unsigned long ulMode = 1;
            if (::ioctlsocket(s, FIONBIO, &ulMode) != 0)
            {
                s 
            = INVALID_SOCKET;
                
            return -1;
            }


            char szHost[128= "www.myhost.com";
            int nPort = 8000;
            char szBuffer[1024= "test socket function.\n"

            addrinfo aiHints;
            addrinfo 
            *aiList = NULL;
            memset(
            &aiHints, 0sizeof(aiHints));
            aiHints.ai_family 
            = AF_INET;
            aiHints.ai_socktype    
            = SOCK_STREAM;
            aiHints.ai_protocol    
            = IPPROTO_TCP;
            if (0 != ::getaddrinfo(szHost, NULL, &aiHints, &aiList))
            {
                
            //m_nLastError = WSAGetLastError();
                ::WSASetLastError(WSAEINVAL);
                
            return -1;
            }


            fd_set fdRead, fdWrite;
            FD_ZERO(
            &fdRead);
            FD_ZERO(
            &fdWrite);
            FD_SET(s, 
            &fdRead);
            FD_SET(s, 
            &fdWrite);
            struct timeval tv;
            tv.tv_sec 
            = 3;
            tv.tv_usec 
            = 0;

            SOCKADDR_IN hostAddr;
            hostAddr 
            = *((SOCKADDR_IN*)aiList->ai_addr);
            hostAddr.sin_port 
            = ::htons(nPort);
            int retCode = ::connect(s, (SOCKADDR*&hostAddr, sizeof(hostAddr));
            if (retCode == SOCKET_ERROR)
            {
                
            int errCode = WSAGetLastError();
                
            if (errCode != WSAEWOULDBLOCK)
                
            {
                    ::closesocket(s);
                    s 
            = INVALID_SOCKET;
                    
            return -1;
                }

            }

            retCode 
            = ::select(0&fdRead, &fdWrite, NULL, &tv);
            if (retCode > 0)
            {
                
            if (FD_ISSET(s, &fdRead))
                
            {
                    printf(
            "error!\n");
                }

                
            if (FD_ISSET(s, &fdWrite))
                
            {
                    
            //connection has succeeded.
                    printf("connect success!\n");
                    FD_SET(s, 
            &fdWrite);
                    FD_ZERO(
            &fdRead);
                    retCode 
            = ::select(0&fdRead, &fdWrite, NULL, &tv);
                    
            if (retCode > 0)
                    
            {
                        
            if (FD_ISSET(s, &fdRead))
                        
            {
                            printf(
            "error!\n");
                        }

                        
            if (FD_ISSET(s, &fdWrite))
                        
            {
                            retCode 
            = send(s, szBuffer, strlen(szBuffer), 0);
                            
            if (retCode > 0)
                            
            {
                                retCode 
            = recv(s, buf, 10230);
                                
            if (retCode == SOCKET_ERROR)
                                
            {
                                    retCode 
            = WSAGetLastError();
                                }

                                
            else if (retCode > 0)
                                
            {
                                    printf(
            "recv %d bytes.\n", retCode);
                                }

                            }

                        }

                    }

                }

            }

            return 0;
            很多問(wèn)題要想深入理解最好的方法就是寫(xiě)一段短的測(cè)試程序驗(yàn)證一下,既不要想當(dāng)然也不要道聽(tīng)途說(shuō)。
            posted on 2011-06-19 22:47 胡雨田 閱讀(506) 評(píng)論(0)  編輯 收藏 引用

            只有注冊(cè)用戶登錄后才能發(fā)表評(píng)論。
            網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問(wèn)   Chat2DB   管理


            亚洲国产成人久久综合野外| 波多野结衣久久| 久久99精品国产麻豆不卡| 国产精品美女久久久久av爽| 亚洲另类欧美综合久久图片区| 久久国产色av免费看| 久久久久久亚洲AV无码专区| 女人香蕉久久**毛片精品| 久久精品中文字幕一区| 久久亚洲AV成人无码电影| 99久久精品国产一区二区蜜芽| 久久精品亚洲精品国产欧美| 一本色道久久综合狠狠躁| 国产免费福利体检区久久| 99久久夜色精品国产网站| 国产精品午夜久久| 久久偷看各类wc女厕嘘嘘| 久久露脸国产精品| 好属妞这里只有精品久久| 老男人久久青草av高清| 久久黄视频| 国产精品久久国产精麻豆99网站| 亚洲精品tv久久久久| 久久国产成人精品国产成人亚洲| 欧美一区二区三区久久综合 | 久久精品人人做人人爽97| 久久久精品久久久久久| 99久久婷婷国产综合精品草原| 97精品依人久久久大香线蕉97| 久久久久香蕉视频| 久久久久综合国产欧美一区二区| 91精品国产综合久久四虎久久无码一级| 97久久精品人妻人人搡人人玩| 人妻丰满AV无码久久不卡| 久久人人爽人人爽人人片AV麻烦| 手机看片久久高清国产日韩 | 国产精品成人久久久久久久| 久久99精品久久久久久久久久| 欧美丰满熟妇BBB久久久| 无码AV中文字幕久久专区| 99久久这里只精品国产免费|