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

            chaosuper85

            C++博客 首頁(yè) 新隨筆 聯(lián)系 聚合 管理
              118 Posts :: 0 Stories :: 3 Comments :: 0 Trackbacks

            為什么會(huì)出現(xiàn)select模型?

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

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

            select模型的出現(xiàn)就是為了解決上述問題。

            select模型的關(guān)鍵是使用一種有序的方式,對(duì)多個(gè)套接字進(jìn)行統(tǒng)一管理與調(diào)度

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

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

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

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

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

            當(dāng)然了,這里演示的只是最基礎(chǔ)的select的用法。網(wǎng)絡(luò)通信中的I/O復(fù)用的相關(guān)問題還很多,還需要慢慢學(xué)習(xí)與深入。
            posted on 2010-01-13 23:04 chaosuper 閱讀(241) 評(píng)論(0)  編輯 收藏 引用

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


            久久婷婷成人综合色综合| 97久久超碰国产精品旧版 | 久久久久亚洲AV无码去区首| 久久99精品久久久久婷婷| 日韩AV无码久久一区二区 | 欧美黑人激情性久久| 国内精品久久久久影院一蜜桃| 久久精品国产秦先生| 久久精品国产只有精品66| 色狠狠久久AV五月综合| 国产精品无码久久综合网| 一本久道久久综合狠狠躁AV| 国产午夜精品理论片久久影视| 欧美激情精品久久久久久久九九九 | 久久婷婷色综合一区二区| 99久久成人国产精品免费| 久久国产精品无| 久久精品国产网红主播| 免费国产99久久久香蕉| 99久久国产精品免费一区二区| 久久无码精品一区二区三区| 99精品久久精品| 久久久久久国产精品无码超碰| 无码国内精品久久人妻麻豆按摩| 亚洲精品国产成人99久久| 激情伊人五月天久久综合| 77777亚洲午夜久久多人| 久久国产综合精品五月天| 韩国三级中文字幕hd久久精品 | 国产精品综合久久第一页| 99久久99这里只有免费的精品| 久久人人爽人人爽人人片av高请| 国产毛片欧美毛片久久久| 久久久久se色偷偷亚洲精品av | 久久精品aⅴ无码中文字字幕重口 久久精品a亚洲国产v高清不卡 | av午夜福利一片免费看久久| 久久综合九色综合网站| 一本色道久久综合亚洲精品| 亚洲中文字幕无码久久精品1| 一本久道久久综合狠狠爱| 亚洲欧美日韩中文久久 |