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

7.3.4 流協議
由于大多面向連接的協議同時也是流式傳輸協議,所以,在此提一下流式協議。對于流套接字上收發數據所用的函數,需要明白的是:它們不能保證對請求的數據量進行讀取或寫入。比如說,一個2 0 4 8字節的字符緩沖,準備用s e n d函數來發送它。采用的代碼是:

char sendBuff[2048];
int? nBytes = 2048;

int ret= 0;
ret = send(s,sendBuff,nBytes,0);

對s e n d函數而言,可能會返回已發出的少于2 0 4 8的字節。r e t變量將設為發送的字節數,這是因為對每個收發數據的套接字來說,系統都為它們分配了相當充足的緩沖區空間。在發送數據時,內部緩沖區會將數據一直保留到應該將它發到線上為止。幾種常見的情況都可導致這一情形的發生。比方說,大量數據的傳輸可以令緩沖區快速填滿。同時,對T C P / I P來說,還有一個窗口大小的問題。接收端會對窗口大小進行調節,以指出它可以接收多少數據。如果有大量數據涌入接收端,接收端就會將窗口大小設為0,為待發數據做好準備。對發送端來
說,這樣會強令它在收到一個新的大于0的窗口大小之前,不得再發數據。在使用s e n d調用時,緩沖區可能只能容納1 0 2 4個字節,這時,便有必要再提取剩下的1 0 2 4個字節。要保證將所有的字節發出去,可采用下面的代碼。

char sendbuf[2048];
int nBytes= 2048,nLeft,idx;

nLeft = nBytes;
idx = 0;

while(nLeft>0)
{
?ret = send(s,&sendbuf[idx],nLeft,0);
?if(ret == SOCKET_ERROR)
?{
??//ERROR
?}
?nLeft -= ret;
?idx +=ret;
?}
?對在流套接字上接收數據來說,前一段代碼有用,但意義不大。因為流套接字是一個不間斷的數據流,應用程序在讀取它時,和它應該讀多少數據之間通常沒有關系。如果應用需要依賴于流協議的離散數據,你就有別的事要做。如果所有消息長度都一樣,則比較簡單,也就是說, 5 1 2個字節的消息看起來就像下面這樣:

char recvbuf[2048];
int ret,nLeft,idx;
nLeft = 512;
idx = 0;

while(nLeft>0)
{
?ret = recv(s,&recvbuf[idx],nLeft,0);
?if(ret = SOCKET_ERROR)
?{
??//ERROR
?}
?idx += ret;
?nLeft -= ret;
}

消息長度不同,處理也可能不同。因此,有必要利用你自己的協議來通知接收端,即將
到來的消息長度是多少。比方說,寫入接收端的前4個字節一直是整數,表示即將到來的消息
有多少字節。然后,接收端先查看前4個字節的方式,把它們轉換成一個整數,然后判斷構成
消息的字節數是多少,通過這種方式,便開始逐次讀取。

分散集合I/O
分散集合支持是Berkeley Socket中首次隨R e c v和Wr i t e v這兩個函數一起出現的概念。
它隨W S A R e c v、W S A R e c v F r o m、W S A S e n d和W S A S e n d To這幾個Winsock 2函數一起使用。
對收發格式特別的數據這一類的應用來說,它是非常有用的。比方說,客戶機發到服務器的消息可能一直都是這樣構成的,一個指定某種操作的固定的3 2字節的頭,一個6 4字節的數據塊和一個1 6字節的尾。這時,就可用一個由三個W S A B U F結構組成的數組調用W S A S e n d,這三個結構分別對應的三種消息類型。在接收端,則用3個W S A B U F結構來調用W S A R e c v,各個結構包含的數據緩沖分別是3 2字節、6 4字節和1 6字節。
在使用基于流的套接字時,分散集合I / O模式只是把W S A B U F結構中提供的數據緩沖當作一個連續性的緩沖。另外,接收調用可能在所有緩沖填滿之前就返回。在基于消息的套接字上,每次對接收操作的調用都會收到一條消息,其長度由所提供的緩沖決定。如果緩沖不夠,調用就會失敗,并出現W S A E M S G S I Z E錯誤,為了適應可用的緩沖數據就會被截斷。當然,如果用支持部分消息的協議,就可用M S G _ PA RT I A L標志來避免數據的丟失。

7.3.5 中斷連接
一旦完成任務,就必須關掉連接,釋放關聯到那個套接字句柄的所有資源。要真正地釋放與一個開著的套接字句柄關聯的資源,執行c l o s e s o c k e t調用即可。但要明白這一點,
c l o s e s o c k e t可能會帶來負面影響(和如何調用它有關),即可能會導致數據的丟失。鑒于此,應該在調用c l o s e s o c k e t函數之前,利用s h u t d o w n函數從容中斷連接。接下來,我們來談談這兩個A P I函數。
1. shutdown
為了保證通信方能夠收到應用發出的所有數據,對一個編得好的應用來說,應該通知接收端“不再發送數據”。同樣,通信方也應該如此。這就是所謂的“從容關閉”方法,并由s h u t d o w n函數來執行。s h u t d o w n的定義如下:

int shutdown(
???????SOCKET s,
???????int how
??????);
h o w參數可以是下面的任何一個值: S D _ R E C E I V E、S D _ S E N D或S D _ B O T H。如果是S D _ R E C E I V E,就表示不允許再調用接收函數。這對底部的協議層沒有影響。另外,對T C P套接字來說,不管數據在等候接收,還是數據接連到達,都要重設連接。盡管如此, U D P套接字上,仍然接受并排列接入的數據。如果選擇S E _ S E N D,表示不允許再調用發送函數。對T C P套接字來說,這樣會在所有數據發出,并得到接收端確認之后,生成一個F I N包。最后,
如果指定S D _ B O T H,則表示取消連接兩端的收發操作。

2. closesocket
c l o s e s o c k e t函數用于關閉套接字,它的定義如下:

int closesocket(SOCKET s);

c l o s e s o c k e t的調用會釋放套接字描述符,再利用套接字執行調用就會失敗,并出現W S A E N O T S O C K錯誤。如果沒有對該套接字的其他引用,所有與其描述符關聯的資源都會被
釋放。其中包括丟棄所有等侯處理的數據。
對這個進程中任何一個線程來說,它們執行的待決異步調用都在未投遞任何通知消息的情況下被刪除。待決的重疊操作也被刪除。與該重疊操作關聯的任何事件,完成例程或完成端口能執行,但最后會失敗,出現W S A _ O P E R AT I O N _ A B O RT E D錯誤。異步和非封鎖I / O模
式將在第8章深入講解。另外,還有一點會對c l o s e s o c k e t的行為產生影響:套接字選項S O _ L I N G E R是否已經設置。要得知其中緣由,參考第9章中對S O _ L I N G E R選項的描述。

Posted on 2006-09-11 17:02 艾凡赫 閱讀(514) 評論(0)  編輯 收藏 引用 所屬分類: 網絡編程
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            久久成人久久爱| 在线综合亚洲欧美在线视频| 亚洲精品一区二区三区99| 欧美深夜影院| 欧美午夜久久久| 国产在线精品二区| 在线日本成人| 亚洲男同1069视频| 久久aⅴ国产紧身牛仔裤| 欧美色欧美亚洲高清在线视频| 久久久综合网站| 欧美成人首页| 欧美日韩亚洲网| 激情小说另类小说亚洲欧美| 亚洲精品一区二区三区不| 在线亚洲免费| 欧美激情第10页| 亚洲欧美在线一区二区| 欧美成人a视频| 国产亚洲高清视频| 一区二区三区国产在线| 久久天天躁狠狠躁夜夜爽蜜月| 亚洲黄色小视频| 欧美一区深夜视频| 亚洲激情网站免费观看| 国产精品99久久久久久久vr| 久久经典综合| 国产色婷婷国产综合在线理论片a| 亚洲激情自拍| 亚洲电影视频在线| 久久人人爽人人| 在线观看国产精品淫| 久久精品国产一区二区三区| 亚洲午夜精品福利| 欧美性色视频在线| 一本久久精品一区二区| 欧美成人首页| 尤妮丝一区二区裸体视频| 暖暖成人免费视频| 狠狠色综合色区| 老司机一区二区三区| 欧美一区二区黄色| 亚洲国产成人一区| 欧美日韩午夜激情| 欧美一区二区三区喷汁尤物| 亚洲欧美激情四射在线日 | 精品成人国产| 另类av一区二区| 欧美电影在线播放| 午夜视频在线观看一区二区三区 | 亚洲一区二区三区在线视频| 国产精品美女在线| 欧美大片一区二区三区| 欧美日韩亚洲综合一区| 久久久久久久一区| 欧美激情影院| 欧美va日韩va| 国产午夜精品一区理论片飘花| 欧美国产日韩视频| 国产亚洲精品一区二区| 99国产精品99久久久久久粉嫩| 国产亚洲人成a一在线v站| 亚洲国产精品电影| 亚洲一区欧美二区| 日韩亚洲欧美成人一区| 老司机午夜精品视频| 久久久久国色av免费看影院 | 欧美精品一区二区在线播放| 欧美在线高清| 国产精品成人在线观看| 亚洲精品欧美| 99精品国产在热久久婷婷| 欧美不卡视频一区| 欧美wwwwww| 最新成人av网站| 欧美久久一级| 一区二区日韩伦理片| 亚洲男女毛片无遮挡| 国产一区二区观看| 久久国产乱子精品免费女| 久久午夜av| 亚洲精品视频在线| 欧美日韩一区二区三区视频 | 久久久久久噜噜噜久久久精品| 国产精品日韩欧美一区二区三区| 亚洲一二三级电影| 欧美大学生性色视频| 9久re热视频在线精品| 国产日韩欧美麻豆| 欧美大色视频| 久久激情五月丁香伊人| 亚洲国产精品久久久久秋霞影院 | 国产深夜精品| 欧美日本一区二区三区| 久久久91精品国产| 亚洲综合欧美日韩| 亚洲国产婷婷| 精品成人国产在线观看男人呻吟| 奶水喷射视频一区| 性色一区二区| 中国成人黄色视屏| 亚洲日韩中文字幕在线播放| 久久野战av| 久久综合中文色婷婷| 久久国产精品一区二区| 中文精品一区二区三区| 亚洲美女电影在线| 91久久中文字幕| 亚洲国产精品久久人人爱蜜臀| 韩国av一区二区三区在线观看| 国产精品一级| 国产精品性做久久久久久| 欧美精品一区二区三区久久久竹菊 | 一区二区三区免费网站| 亚洲福利视频在线| 亚洲国产天堂久久国产91| 欧美黄色影院| 亚洲欧洲一区| 正在播放亚洲一区| 中文在线资源观看网站视频免费不卡| 亚洲精品一区二区三区蜜桃久| 亚洲精品网站在线播放gif| 一本在线高清不卡dvd| 小辣椒精品导航| 欧美成人精品不卡视频在线观看| 久久久久综合一区二区三区| 久久久91精品国产| 欧美激情一区三区| 国产亚洲一本大道中文在线| 国产女人aaa级久久久级| 悠悠资源网久久精品| 蜜桃伊人久久| 欧美日韩ab| 合欧美一区二区三区| 一区二区免费在线播放| 久久久久久久999| 一道本一区二区| 老鸭窝亚洲一区二区三区| 欧美午夜视频| 99国内精品久久| 亚洲激情影视| 欧美不卡一区| 亚洲精品免费在线观看| 毛片一区二区| 麻豆av一区二区三区久久| 狠狠88综合久久久久综合网| 欧美专区在线观看| 久久爱www| 一区二区三区在线免费视频| 久久久精品一区| 久久精品国产精品亚洲| 伊人春色精品| 亚洲黄一区二区三区| 欧美日韩999| 在线亚洲精品| 亚洲在线第一页| 国语自产精品视频在线看抢先版结局| 久久九九全国免费精品观看| 欧美一区二区三区的| 伊人久久婷婷| 中文精品一区二区三区| 国产一区二区0| 蜜桃久久精品乱码一区二区| 欧美电影在线| 欧美在线不卡视频| 免费一区二区三区| 亚洲欧美www| 久久久一二三| 午夜精品久久久久久久99樱桃| 亚洲综合日韩| 亚洲三级视频| 欧美中文字幕| 中文欧美在线视频| 猛男gaygay欧美视频| 亚洲欧美一区在线| 欧美激情综合色| 国语自产精品视频在线看8查询8| 老司机凹凸av亚洲导航| 欧美激情在线播放| 免费视频久久| 国产欧美一区二区三区久久人妖 | 亚洲午夜激情| 欧美电影免费网站| 久久三级视频| 国产麻豆精品视频| 中文日韩在线视频| 亚洲性夜色噜噜噜7777| 欧美国内亚洲| 亚洲精品影院在线观看| 亚洲国产视频一区二区| 麻豆成人在线| 亚洲国产精品国自产拍av秋霞| 在线观看日韩www视频免费| 久久精品在线播放| 欧美成人免费在线| 亚洲日本理论电影| 欧美电影免费| 亚洲一区二区在线免费观看视频 | 一区二区久久久久久| 亚洲一级一区|