青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

第8章Winsock I/O方法
本章重點(diǎn)是如何在Wi n d o w s套接字應(yīng)用程序中對(duì)I / O(輸入/輸出)操作進(jìn)行管理。
Wi n s o c k分別提供了“套接字模式”和“套接字I / O模型”,可對(duì)一個(gè)套接字上的I / O行為加以控制。其中,套接字模式用于決定在隨一個(gè)套接字調(diào)用時(shí),那些Wi n s o c k函數(shù)的行為。而另一方面,套接字模型描述了一個(gè)應(yīng)用程序如何對(duì)套接字上進(jìn)行的I / O進(jìn)行管理及處理。要注意的是,“套接字I / O模型”與“套接字模式”是無(wú)關(guān)的。套接字模型的出現(xiàn),正是為了解決套接字模式存在的某些限制。

Wi n s o c k提供了兩種套接字模式:鎖定和非鎖定。本章第一部分將詳細(xì)介紹這兩種模式,并闡釋一個(gè)應(yīng)用程序如何通過(guò)它們管理I / O。如大家在本章的后面部分所見,Wi n s o c k提供了一些有趣的I / O模型,有助于應(yīng)用程序通過(guò)一種“異步”方式,一次對(duì)一個(gè)或多個(gè)套接字上進(jìn)行的通信加以管理。這些模型包括s e l e c t(選擇)、W S A A s y n c S e l e c t(異步選擇)、W S A E v e n t S e l e c t
(事件選擇)、Overlapped I/O(重疊式I / O)以及Completion port(完成端口)等等。到本章結(jié)束時(shí),我們打算對(duì)各種套接字模式以及I / O模型的優(yōu)缺點(diǎn)進(jìn)行總結(jié)。同時(shí),幫助大家判斷到底哪一種最適合自己應(yīng)用程序的要求。
所有Wi n d o w s平臺(tái)都支持套接字以鎖定或非鎖定方式工作。然而,并非每種平臺(tái)都支持每一種I / O模型。如表8 - 1所示,在當(dāng)前版本的Windows CE 中,僅提供了一個(gè)I / O模型。
Windows 98和Windows 95(取決于安裝的是Winsock 1還是Winsock 2)則支持大多數(shù)I / O模型,唯一的例外便是I / O完成端口。而到了Windows NT和最新發(fā)布的Windows 2000中,每種I / O模型都是支持的。

8.1 套接字模式
就像我們前面提到的那樣, Wi n d o w s套接字在兩種模式下執(zhí)行I / O操作:鎖定和非鎖定。
在鎖定模式下,在I / O操作完成前,執(zhí)行操作的Wi n s o c k函數(shù)(比如s e n d和r e c v)會(huì)一直等候下去,不會(huì)立即返回程序(將控制權(quán)交還給程序)。而在非鎖定模式下, Wi n s o c k函數(shù)無(wú)論如何都會(huì)立即返回。在Windows CE和Windows 95(安裝Winsock 1)平臺(tái)上運(yùn)行的應(yīng)用程序僅支持極少的I / O模型,所以我們必須采取一些適當(dāng)?shù)牟襟E,讓鎖定和非鎖定套接字能夠滿足各種場(chǎng)合的要求

8.1.1 鎖定模式
對(duì)于處在鎖定模式的套接字,我們必須多加留意,因?yàn)樵谝粋€(gè)鎖定套接字上調(diào)用任何一個(gè)Winsock API函數(shù),都會(huì)產(chǎn)生相同的后果—耗費(fèi)或長(zhǎng)或短的時(shí)間“等待”。大多數(shù)Wi n s o c k應(yīng)用都是遵照一種“生產(chǎn)者-消費(fèi)者”模型來(lái)編制的。在這種模型中,應(yīng)用程序需要讀取(或?qū)懭耄┲付〝?shù)量的字節(jié),然后以它為基礎(chǔ)執(zhí)行一些計(jì)算。程序清單8 - 1展示的代碼片斷便是一個(gè)典型的例子。

// 程序清單8-1?簡(jiǎn)單的鎖定模式示例

SOCKET?s;
char ?buff[ 256 ];
int ?done? = ? 0 ;

.

while ( ! done)
{
????nBytes?
= ?recv(s,buff, 65 );
????
if (nBytes? == ?SOCKET_ERROR)
????
{
????????printf(
" recv?failed?with?error?%d " ,WSAGetLastError());
????????
return ?;????
????}

????
????
}

.


這段代碼的問(wèn)題在于,假如沒(méi)有數(shù)據(jù)處于“待決”狀態(tài),那么r e c v函數(shù)可能永遠(yuǎn)都無(wú)法返回。這是由于從語(yǔ)句可以看出:只有從系統(tǒng)的輸入緩沖區(qū)中讀回點(diǎn)什么東西,才允許返回!有些程序員可能會(huì)在r e c v中使用M S G _ P E E K標(biāo)志,或者調(diào)用i o c t l s o c k e( t 設(shè)置F I O N R E A D選項(xiàng)),
在系統(tǒng)的緩沖區(qū)中,事先“偷看”是否存在足夠的字節(jié)數(shù)量。然而,在不實(shí)際讀入數(shù)據(jù)的前提下,僅僅“偷看”數(shù)據(jù)(如實(shí)際讀入數(shù)據(jù),便會(huì)將其從系統(tǒng)緩沖區(qū)中將其刪除),可不是一件光彩的事情。我們認(rèn)為,這是一種非常不好的編程習(xí)慣,應(yīng)盡全力避免。在“偷看”的時(shí)候,對(duì)系統(tǒng)造成的開銷是極大的,因?yàn)閮H僅為了檢查有多少個(gè)字節(jié)可用,便發(fā)出一個(gè)或者更多的系統(tǒng)調(diào)用。以后,理所當(dāng)然地,還需要牽涉到進(jìn)行實(shí)際r e c v調(diào)用,將數(shù)據(jù)從系統(tǒng)緩沖區(qū)內(nèi)刪除的開銷。那么,如何避免這一情況呢?在此,我們的目標(biāo)是防止由于數(shù)據(jù)的缺乏(這
可能是網(wǎng)絡(luò)出了故障,也可能是客戶機(jī)出了問(wèn)題),造成應(yīng)用程序完全陷于“凝固”狀態(tài),同時(shí)不必連續(xù)性地檢視系統(tǒng)網(wǎng)絡(luò)緩沖!為達(dá)此目的,一個(gè)辦法是將應(yīng)用程序劃分為一個(gè)讀線程,以及一個(gè)計(jì)算線程。兩個(gè)線程都共享同一個(gè)數(shù)據(jù)緩沖區(qū)。對(duì)這個(gè)緩沖區(qū)的訪問(wèn)需要受到一定的限制,這是用一個(gè)同步對(duì)象來(lái)實(shí)現(xiàn)的,比如一個(gè)事件或者M(jìn) u t e x(互斥體)。“讀線程”的職責(zé)是從網(wǎng)絡(luò)連續(xù)地讀入數(shù)據(jù),并將其置入共享緩沖區(qū)內(nèi)。讀線程將計(jì)算線程開始工作至少需
要的數(shù)據(jù)量拿到手后,便會(huì)觸發(fā)一個(gè)事件,通知計(jì)算線程:你老兄可以開始干活了!隨后,計(jì)算線程從緩沖區(qū)取走(刪除)一個(gè)數(shù)據(jù)塊,然后進(jìn)行要求的計(jì)算。

在程序清單8 - 2中,我們分別提供了兩個(gè)函數(shù),采取的便是上述辦法。在兩個(gè)函數(shù)中,一個(gè)負(fù)責(zé)讀取網(wǎng)絡(luò)數(shù)據(jù)( R e a d T h r e a d),另一個(gè)則負(fù)責(zé)對(duì)數(shù)據(jù)執(zhí)行計(jì)算( P r o c e s s T h r e a d)。

// 程序清單8-2?多線程的鎖定套接字示例

CRITICAL_SECTION????data;
HANDLE????hEvent;
TCHAR?????buf[MAX_BUFFER_SIZE];
int ?????????nBytes;

.

// read?thread

void ?ReadThread( void )
{
????
int ?nTotal? = ? 0 ,
????????????nRead?
= ? 0 ,
????????????nLeft?
= ? 0 ,
????????????nBytes?
= ? 0 ;
????????????
????????????
while ( ! done)
????????????
{
????????????????nTotal?
= ? 0 ;
????????????????nLeft?
= ?NUM_BYTES_REQUIRED;
????????????????
while (nTotal? != ?NUM_BYTES_REQUIRED)
????????????????
{
????????????????????EnterCriticalSection(
& data);
????????????????????nRead?
= ?recv(sock, & (buff[MAX_BUFFERS_SIZE - nBytes],nLeft);
????????????????????
if (nRead? == ? - 1 )
????????????????????
{
????????????????????????printf(
" error " );
????????????????????????ExitThread();
????????????????????}

????????????????????nTotal?
+= ?nRead;
????????????????????nLeft?
-= nRead;
????????????????????
????????????????????nBytes?
+= ?nRead;
????????????????????LeaveCriticalSection(
& data);
????????????????????
????????????????}

????????????????SetEvent(hEvent);
????????????}

}


////// compution?thread

void ????ProcessThread( void )
{
????WatiForSingleObject(hEvent);
????
????EnterCriticalSection(
& data);
????..
????nBytes?
-= ?NUM_BYTES_REQUIRED;
????
????LeaveCriticalSection(
& data);
}



對(duì)鎖定套接字來(lái)說(shuō),它的一個(gè)缺點(diǎn)在于:應(yīng)用程序很難同時(shí)通過(guò)多個(gè)建好連接的套接字通信。使用前述的辦法,我們可對(duì)應(yīng)用程序進(jìn)行修改,令其為連好的每個(gè)套接字都分配一個(gè)讀線程,以及一個(gè)數(shù)據(jù)處理線程。盡管這仍然會(huì)增大一些開銷,但的確是一種可行的方案。唯一的缺點(diǎn)便是擴(kuò)展性極差,以后想同時(shí)處理大量套接字時(shí),恐怕難以下手。
Posted on 2006-09-11 17:48 艾凡赫 閱讀(641) 評(píng)論(0)  編輯 收藏 引用 所屬分類: 網(wǎng)絡(luò)編程
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            欧美婷婷在线| 亚洲乱码国产乱码精品精天堂 | 久久人人爽人人爽| 午夜视频久久久久久| 性做久久久久久| 欧美一区二区三区四区在线观看| 久久国产视频网站| 嫩草国产精品入口| 日韩视频永久免费| 亚洲自拍偷拍一区| 久久久91精品国产一区二区三区 | 欧美亚洲第一页| 国产真实乱子伦精品视频| 亚洲大片精品永久免费| 一本到高清视频免费精品| 亚洲欧美一区在线| 欧美96在线丨欧| 一二三区精品| 久久精品官网| 欧美亚韩一区| 亚洲激情影院| 欧美一区三区三区高中清蜜桃| 狂野欧美激情性xxxx| 亚洲精品在线观看免费| 欧美在线免费观看亚洲| 欧美极品在线播放| 国模私拍一区二区三区| 在线一区日本视频| 欧美+日本+国产+在线a∨观看| 日韩午夜精品| 久久综合久久综合这里只有精品| 欧美日韩一区二区在线视频| 欧美日韩国产影片| 国产精品日韩久久久| 欧美精品二区三区四区免费看视频| 欧美日韩高清免费| 在线电影欧美日韩一区二区私密| 亚洲视频在线观看| 亚洲第一中文字幕| 亚洲影院色无极综合| 欧美高清在线一区二区| 黄色在线成人| 久久大香伊蕉在人线观看热2| 91久久久久久久久久久久久| 性欧美1819性猛交| 国产精品久久久久久久久久ktv| 亚洲人线精品午夜| 欧美va亚洲va国产综合| 久久精彩视频| 激情久久中文字幕| 久久资源av| 久久久久www| 精品51国产黑色丝袜高跟鞋| 欧美一区二区三区在线视频| 一区二区三区欧美激情| 欧美日韩午夜激情| 中文日韩欧美| 正在播放亚洲一区| 国产精品乱子久久久久| 亚洲宅男天堂在线观看无病毒| 亚洲国产欧美一区二区三区同亚洲| 久久久久一区二区| 亚洲国产美女精品久久久久∴| 你懂的国产精品| 你懂的视频一区二区| 亚洲激情在线视频| 亚洲片区在线| 欧美日韩亚洲一区二区| 亚洲午夜久久久久久久久电影网| 亚洲伦理在线观看| 国产精品v欧美精品v日韩| 亚洲一区二区免费在线| 亚洲一区二区三区中文字幕| 国产精品无码专区在线观看 | 激情一区二区| 男人的天堂亚洲在线| 欧美chengren| 这里只有精品视频| 亚洲欧美日本伦理| 国产一区自拍视频| 欧美激情精品| 国产精品久久久久久久久久直播| 欧美永久精品| 欧美大片免费观看在线观看网站推荐| 日韩亚洲欧美一区| 亚洲免费视频一区二区| 韩国一区二区三区美女美女秀| 欧美成人免费播放| 欧美午夜视频在线观看| 亚洲婷婷综合色高清在线| 亚洲一区在线播放| 狠狠色狠狠色综合| 亚洲激情婷婷| 国产精品亚洲综合久久| 欧美成人一区二区| 国产精品国产三级国产专区53| 久久久久久97三级| 欧美日韩国产欧| 麻豆freexxxx性91精品| 欧美日韩国产影片| 乱人伦精品视频在线观看| 欧美日韩国产一区二区三区| 久久久精品性| 国产精品xnxxcom| 亚洲第一色中文字幕| 国产夜色精品一区二区av| 亚洲精品你懂的| 在线看无码的免费网站| 亚洲无线视频| av成人福利| 久久午夜av| 久久精品一区二区三区不卡牛牛| 欧美日韩1080p| 欧美高清日韩| 韩国精品一区二区三区| 亚洲自啪免费| 亚洲免费在线视频| 欧美日韩网站| 亚洲欧洲一区二区三区在线观看| 激情丁香综合| 欧美在线免费观看| 久久久久99精品国产片| 国产精品拍天天在线| 亚洲最新视频在线| 一二三四社区欧美黄| 欧美激情视频网站| 亚洲国产精品久久久| 亚洲国产国产亚洲一二三| 欧美中文字幕不卡| 久久久噜噜噜久久久| 国产在线精品一区二区夜色| 亚洲女性喷水在线观看一区| 亚洲综合精品自拍| 国产精品国产a级| 亚洲系列中文字幕| 欧美一区二区三区在线视频| 国产精品视频久久久| 亚洲永久免费视频| 久久不射2019中文字幕| 国产视频亚洲| 久久精品中文字幕一区| 久久人人爽爽爽人久久久| 韩日在线一区| 美女久久网站| 亚洲黄色在线观看| 亚洲午夜久久久| 国产精品亚洲综合色区韩国| 亚洲欧美国产精品专区久久| 久久精品五月婷婷| 在线观看国产日韩| 欧美成人首页| 一区二区三区四区国产| 欧美一区二区在线看| 国产一区二区精品久久91| 久久精品72免费观看| 欧美福利网址| 亚洲视频免费看| 欧美日韩你懂的| 欧美专区中文字幕| 久久久国产精品一区二区中文| 精品二区视频| 欧美激情bt| 亚洲免费视频在线观看| 麻豆久久婷婷| 亚洲午夜精品一区二区三区他趣| 国产欧美91| 免费欧美日韩国产三级电影| 99国产精品久久久久久久成人热| 欧美亚洲视频一区二区| 尤物精品在线| 国产精品www网站| 久久综合伊人77777麻豆| 夜夜爽www精品| 久久青草欧美一区二区三区| 99v久久综合狠狠综合久久| 国产精品一区二区三区四区| 裸体丰满少妇做受久久99精品| 一二三四社区欧美黄| 久久综合亚州| 亚洲欧美不卡| 日韩亚洲欧美一区| 精品9999| 国产三级精品三级| 欧美日韩国产限制| 欧美制服第一页| 亚洲视频一区二区在线观看| 久久亚洲国产精品一区二区 | 中国成人亚色综合网站| 韩日成人av| 国产农村妇女精品一二区| 欧美区二区三区| 免费不卡视频| 久久精品官网| 亚洲欧美网站| 亚洲私拍自拍| 亚洲伦理一区| 亚洲精品视频在线播放| 欧美国产日韩一区二区| 久久人人看视频| 久久久青草青青国产亚洲免观|