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

            孔雀開發小屋

            專注并致力于手機客戶端開發
            <2009年12月>
            293012345
            6789101112
            13141516171819
            20212223242526
            272829303112
            3456789

            統計

            • 隨筆 - 103
            • 文章 - 0
            • 評論 - 251
            • 引用 - 0

            常用鏈接

            留言簿(38)

            隨筆分類

            隨筆檔案

            關注的博客

            朋友的博客

            搜索

            •  

            最新評論

            閱讀排行榜

            評論排行榜

            網絡通信模型之select模型

            為什么會出現select模型?

            先看一下下面的這句代碼:
            int iResult = recv(s, buffer,1024);
            這是用來接收數據的,在默認的阻塞模式下的套接字里,recv會阻塞在那里,直到套接字連接上有數據可讀,把數據讀到buffer里后recv函數才會返 回,不然就會一直阻塞在那里。在單線程的程序里出現這種情況會導致主線程(單線程程序里只有一個默認的主線程)被阻塞,這樣整個程序被鎖死在這里,如果永 遠沒數據發送過來,那么程序就會被永遠鎖死。這個問題可以用多線程解決,但是在有多個套接字連接的情況下,這不是一個好的選擇,擴展性很差。
            再看代碼:
            int iResult = ioctlsocket(s, FIOBIO, (unsigned long *)&ul);
            iResult = recv(s, buffer,1024);

            這一次recv的調用不管套接字連接上有沒有數據可以接收都會馬上返回。原因就在于我們用ioctlsocket把套接字設置為非阻塞模式了。不過 你跟蹤 一下就會發現,在沒有數據的情況下,recv確實是馬上返回了,但是也返回了一個錯誤:WSAEWOULDBLOCK,意思就是請求的操作沒有成功完成。 看到這里很多人可能會說,那么就重復調用recv并檢查返回值,直到成功為止,但是這樣做效率很成問題,開銷太大。

            select模型的出現就是為了解決上述問題。

            select模型的關鍵是使用一種有序的方式,對多個套接字進行統一管理與調度

            看核心代碼:(這里只給出服務端的)

            while ( 1 )
            {
            // 初始化fdset
            FD_ZERO( &fdsRead );

            // 將server套接字添加到可讀集合中
            FD_SET( sockServer, &fdsRead );

            // 調用select
            select( 0, &fdsRead, NULL, NULL, &tv );

            // 判斷server套接字的狀態,如果套接字還在可讀集合中,
            // 說明有數據可以讀入,則建立套接字可以成功
            if ( FD_ISSET( sockServer, &fdsRead ) )
            {
            sockAccept = accept( sockServer, (sockaddr*)&addr, &nLen );
            // 有數據可讀,進行相關處理
            }

            當然了,這里演示的只是最基礎的select的用法。網絡通信中的I/O復用的相關問題還很多,還需要慢慢學習與深入。


            posted on 2010-01-13 22:55 孔雀 閱讀(2938) 評論(0)  編輯 收藏 引用

            久久精品?ⅴ无码中文字幕| 国产成人精品久久| 国产日韩欧美久久| 要久久爱在线免费观看| 97精品久久天干天天天按摩| 日本福利片国产午夜久久| 一级做a爰片久久毛片看看| 色偷偷88888欧美精品久久久| 亚洲国产天堂久久综合网站| 亚洲午夜无码AV毛片久久| 99久久精品国产麻豆| 一本一道久久a久久精品综合| 国产精品视频久久久| 精品无码久久久久国产动漫3d| 久久婷婷综合中文字幕| 亚洲va久久久噜噜噜久久天堂| 久久久九九有精品国产| 婷婷伊人久久大香线蕉AV| yy6080久久| 亚洲&#228;v永久无码精品天堂久久| 麻豆成人久久精品二区三区免费| 久久精品国产72国产精福利| 久久国产乱子伦精品免费强| 亚洲国产另类久久久精品| 久久久久久国产a免费观看黄色大片 | 久久超乳爆乳中文字幕| 亚洲日韩欧美一区久久久久我| 国内精品免费久久影院| 国产99久久久国产精品~~牛| 国产美女久久精品香蕉69| 久久天堂AV综合合色蜜桃网| 婷婷伊人久久大香线蕉AV | 久久久精品人妻无码专区不卡| 国产一级持黄大片99久久| 99麻豆久久久国产精品免费| 99久久人妻无码精品系列| 77777亚洲午夜久久多喷| 久久亚洲高清观看| 久久99久久成人免费播放| 久久久久久极精品久久久| 天天综合久久一二三区|