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

            孔雀開發小屋

            專注并致力于手機客戶端開發
            <2010年1月>
            272829303112
            3456789
            10111213141516
            17181920212223
            24252627282930
            31123456

            統計

            • 隨筆 - 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 孔雀 閱讀(2936) 評論(0)  編輯 收藏 引用

            国产韩国精品一区二区三区久久| 久久综合欧美成人| 久久精品日日躁夜夜躁欧美| 精品久久久久成人码免费动漫| 久久天天躁狠狠躁夜夜2020老熟妇| 国产精品青草久久久久福利99| 久久电影网| 色欲综合久久中文字幕网| 99久久免费国产精品| 久久亚洲中文字幕精品一区| 成人综合伊人五月婷久久| 久久免费视频一区| 国内精品久久人妻互换| 香港aa三级久久三级老师2021国产三级精品三级在 | 久久久这里有精品中文字幕| 久久久久se色偷偷亚洲精品av| 久久国产精品成人片免费| 性高朝久久久久久久久久| 亚洲国产精品久久久久婷婷软件 | 国产精品九九久久免费视频| 亚洲乱码日产精品a级毛片久久 | 精品久久久久久久久中文字幕| 精品无码久久久久久久动漫| 久久无码人妻一区二区三区午夜| 久久伊人精品青青草原日本| 久久香蕉国产线看观看99| 欧美精品久久久久久久自慰| 欧美亚洲国产精品久久高清| 久久久WWW成人| 久久久久久久久久久免费精品| 青青青国产成人久久111网站| 久久久久国产精品熟女影院| 中文字幕无码免费久久| 日韩人妻无码一区二区三区久久99| 久久精品免费网站网| 91精品国产综合久久香蕉| 国产91色综合久久免费| 91久久婷婷国产综合精品青草 | 伊人久久综在合线亚洲2019| AV无码久久久久不卡蜜桃| av国内精品久久久久影院|