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

天下

記錄修行的印記

socket函數send和recv函數


在發送端,一次發送4092個字節,
在接收端,一次接收4092個字節,
但是在接收端,偶爾會出現 socket.receive 接收不全的情況 ,

ret 
= sock.recv(bBuffer,iBufferLen,0); //也有可能無法收到全部數據!
必須要考慮0 < ret < iBufferLen的情況:繼續接收iBufferLen - ret字節,然后合并
注意第recv函數的第四個參數:
MSG_WAITALL The receive request will complete only when one of the following events occurs:
  • The buffer supplied by the caller is completely full.
  • The connection has been closed.
  • The request has been canceled.
Note that if the underlying transport does not support MSG_WAITALL, or if the socket is in a non-blocking mode, then this call will fail with WSAEOPNOTSUPP. Also, if MSG_WAITALL is specified along with MSG_OOB, MSG_PEEK, or MSG_PARTIAL, then this call will fail with WSAEOPNOTSUPP. This flag is not supported on datagram sockets or message-oriented CO sockets.


Socket的Send,Recv的長度問題:

一個包沒有固定長度,以太網限制在46-1500字節,1500就是以太網的MTU,超過這個量,TCP會為IP數據報設置偏移量進行分片傳輸,現在一般可允許應用層設置8k(NTFS系統)的緩沖區,8k的數據由底層分片,而應用層看來只是一次發送。
windows的緩沖區經驗值是4k。
Socket本身分為兩種,流(TCP)和數據報(UDP),你的問題針對這兩種不同使用而結論不一樣。甚至還和你是用阻塞、還是非阻塞Socket來編程有關。
1、通信長度,這個是你自己決定的,沒有系統強迫你要發多大的包,實際應該根據需求和網絡狀況來決定。對于TCP,這個長度可以大點,但要知道,Socket內部默認的收發緩沖區大小大概是8K,你可以用SetSockOpt來改變。但對于UDP,就不要太大,一般在1024至10K。注意一點,你無論發多大的包,IP層和鏈路層都會把你的包進行分片發送,一般局域網就是1500左右,廣域網就只有幾十字節。分片后的包將經過不同的路由到達接收方,對于UDP而言,要是其中一個分片丟失,那么接收方的IP層將把整個發送包丟棄,這就形成丟包。顯然,要是一個UDP發包佷大,它被分片后,鏈路層丟失分片的幾率就佷大,你這個UDP包,就佷容易丟失,但是太小又影響效率。最好可以配置這個值,以根據不同的環境來調整到最佳狀態。
send()函數返回了實際發送的長度,在網絡不斷的情況下,它絕不會返回(發送失敗的)錯誤,最多就是返回0。對于TCP你可以寫一個循環發送。當send函數返回SOCKET_ERROR時,才標志著有錯誤。但對于UDP,你不要寫循環發送,否則將給你的接收帶來極大的麻煩。所以UDP需要用SetSockOpt來改變Socket內部Buffer的大小,以能容納你的發包。明確一點,TCP作為流,發包是不會整包到達的,而是源源不斷的到,那接收方就必須組包。而UDP作為消息或數據報,它一定是整包到達接收方。
2、關于接收,一般的發包都有包邊界,首要的就是你這個包的長度要讓接收方知道,于是就有個包頭信息,對于TCP,接收方先收這個包頭信息,然后再收包數據。一次收齊整個包也可以,可要對結果是否收齊進行驗證。這也就完成了組包過程。UDP,那你只能整包接收了。要是你提供的接收Buffer過小,TCP將返回實際接收的長度,余下的還可以收,而UDP不同的是,余下的數據被丟棄并返回WSAEMSGSIZE錯誤。注意TCP,要是你提供的Buffer佷大,那么可能收到的就是多個發包,你必須分離它們,還有就是當Buffer太小,而一次收不完Socket內部的數據,那么Socket接收事件(OnReceive),可能不會再觸發,使用事件方式進行接收時,密切注意這點。這些特性就是體現了流和數據包的區別。
補充一點,接收BuffSize 
>= 發送BuffSize >= 實際發送Size,對于內外部的Buffer都適用,上面講的主要是Socket內部的Buffer大小關系。
3、TCP是有多少就收多少,如果沒有當然阻塞Socket的recv就會等,直到有數據,非阻塞Socket不好等,而是返回WSAEWOULDBLOCK。UDP,如果沒有數據,阻塞Socket就會等,非阻塞Socket也返回WSAEWOULDBLOCK。如果有數據,它是會等整個發包到齊,并接收到整個發包,才返回。

send函數
int send( SOCKET s,const char* buf,int len,int flags);

不論是客戶還是服務器應用程序都用send函數來向TCP連接的另一端發送數據。

客戶程序一般用send函數向服務器發送請求,而服務器則通常用send函數來向客戶程序發送應答。

該函數的第一個參數指定發送端套接字描述符;

第二個參數指明一個存放應用程序要發送數據的緩沖區;

第三個參數指明實際要發送的數據的字節數;

第四個參數一般置0。

這里只描述同步Socket的send函數的執行流程。當調用該函數時,send先比較待發送數據的長度len和套接字s的發送緩沖的 長度,如果len大于s的發送緩沖區的長度,該函數返回SOCKET_ERROR;如果len小于或者等于s的發送緩沖區的長度,那么send先檢查協議 是否正在發送s的發送緩沖中的數據,如果是就等待協議把數據發送完,如果協議還沒有開始發送s的發送緩沖中的數據或者s的發送緩沖中沒有數據,那么 send就比較s的發送緩沖區的剩余空間和len,如果len大于剩余空間大小send就一直等待協議把s的發送緩沖中的數據發送完,如果len小于剩余 空間大小send就僅僅把buf中的數據copy到剩余空間里(注意并不是send把s的發送緩沖中的數據傳到連接的另一端的,而是協議傳的,send僅僅是把buf中的數據copy到s的發送緩沖區的剩余空間里)。如果send函數copy數據成功,就返回實際copy的字節數,如果send在copy數據時出現錯誤,那么send就返回SOCKET_ERROR;如果send在等待協議傳送數據時網絡斷開的話,那么send函數也返回SOCKET_ERROR。

要注意send函數把buf中的數據成功copy到s的發送緩沖的剩余空間里后它就返回了,但是此時這些數據并不一定馬上被傳到連接的另一端。如 果協議在后續的傳送過程中出現網絡錯誤的話,那么下一個Socket函數就會返回SOCKET_ERROR。(每一個除send外的Socket函數在執 行的最開始總要先等待套接字的發送緩沖中的數據被協議傳送完畢才能繼續,如果在等待時出現網絡錯誤,那么該Socket函數就返回 SOCKET_ERROR)

注意:在Unix系統下,如果send在等待協議傳送數據時網絡斷開的話,調用send的進程會接收到一個SIGPIPE信號,進程對該信號的默認處理是進程終止。

recv函數

int recv( SOCKET s,char* buf,int len,int flags);   

不論是客戶還是服務器應用程序都用recv函數從TCP連接的另一端接收數據。

該函數的第一個參數指定接收端套接字描述符;

第二個參數指明一個緩沖區,該緩沖區用來存放recv函數接收到的數據;

第三個參數指明buf的長度;

第四個參數一般置0。

這里只描述同步Socket的recv函數的執行流程。當應用程序調用recv函數時,recv先等待s的發送緩沖 中的數據被協議傳送完畢,如果協議在傳送s的發送緩沖中的數據時出現網絡錯誤,那么recv函數返回SOCKET_ERROR,如果s的發送緩沖中沒有數 據或者數據被協議成功發送完畢后,recv先檢查套接字s的接收緩沖區,如果s接收緩沖區中沒有數據或者協議正在接收數據,那么recv就一直等待,只到 協議把數據接收完畢。當協議把數據接收完畢,recv函數就把s的接收緩沖中的數據copy到buf中(注意協議接收到的數據可能大于buf的長度,所以 在這種情況下要調用幾次recv函數才能把s的接收緩沖中的數據copy完。recv函數僅僅是copy數據,真正的接收數據是協議來完成的),recv函數返回其實際copy的字節數。如果recv在copy時出錯,那么它返回SOCKET_ERROR;如果recv函數在等待協議接收數據時網絡中斷了,那么它返回0。

注意:在Unix系統下,如果recv函數在等待協議接收數據時網絡斷開了,那么調用recv的進程會接收到一個SIGPIPE信號,進程對該信號的默認處理是進程終止。


#include 
"socketclient.h"
int main()
{
    SocketClient cli;
    
char* szIp    = "127.0.0.1";
    WORD  wPort 
= 5082;
    
int nRet = cli.Open(szIp,wPort);
    
if (nRet!=0)
    {
        printf(
"Open %s:%d error:%d \r\n",szIp,wPort,nRet);
        
return -1;
    }
    
char buf[1600];
    
int i=1;
    DWORD dwTickCount0 
= 0;
    DWORD dwTickCount1 
= 0;
    
int nSended = 0;
    
while (1)
    {
        dwTickCount0 
= cli.GetTickCount();
        
//printf("%d,TickCount(0):%u \r\n",i,dwTickCount0);

        nSended 
= cli.Send(buf,1500); //超時2秒發送

        dwTickCount1 
= cli.GetTickCount();
        
//printf("%d,TickCount(1):%u \r\n",i,dwTickCount1);
        
//usleep(20*100);
        printf("%d,time:%u,sended:%d,err:%d \r\n",i,dwTickCount1 - dwTickCount0,nSended,errno);
        
if (nSended<1)
        {
            
break;
        }
        i
++;
    }
}

1,time:0,sended:1500,err:0 
2,time:0,sended:1500,err:0 
3,time:0,sended:1500,err:0 
4,time:0,sended:1500,err:0 
5,time:0,sended:1500,err:0 
6,time:0,sended:1500,err:0 
7,time:0,sended:1500,err:0 
8,time:1,sended:1500,err:0 
9,time:0,sended:1500,err:0 
10,time:0,sended:1500,err:0 
11,time:0,sended:1500,err:0 
12,time:0,sended:1500,err:0 
13,time:0,sended:1500,err:0 
14,time:0,sended:1500,err:0 
15,time:0,sended:1500,err:0 
16,time:0,sended:1500,err:0 
17,time:0,sended:1500,err:0 
18,time:0,sended:1500,err:0 
19,time:0,sended:1500,err:0 
20,time:0,sended:1500,err:0 
21,time:0,sended:1500,err:0 
22,time:0,sended:1500,err:0 
23,time:0,sended:1500,err:0 
24,time:0,sended:1500,err:0 
25,time:0,sended:1500,err:0 
26,time:0,sended:1500,err:0 
27,time:0,sended:1500,err:0 
28,time:0,sended:1500,err:0 
29,time:0,sended:1500,err:0 
30,time:0,sended:1500,err:0 
31,time:0,sended:1500,err:0 
32,time:0,sended:1500,err:0 
33,time:0,sended:1500,err:0 
34,time:0,sended:1500,err:0 
35,time:0,sended:1500,err:0 
36,time:0,sended:1500,err:0 
37,time:0,sended:1500,err:0 
38,time:0,sended:1500,err:0 
39,time:0,sended:1500,err:0 
40,time:0,sended:1500,err:0 
41,time:0,sended:1500,err:0 
42,time:0,sended:1500,err:0 
43,time:0,sended:1500,err:0 
44,time:0,sended:1500,err:0 
45,time:0,sended:1500,err:0 
46,time:0,sended:1500,err:0 
47,time:0,sended:1500,err:0 
48,time:39,sended:1500,err:0 
49,time:0,sended:1500,err:0 
50,time:0,sended:1500,err:0 
51,time:0,sended:1500,err:0 
52,time:0,sended:1500,err:0 
53,time:0,sended:1500,err:0 
54,time:0,sended:1500,err:0 
55,time:0,sended:1500,err:0 
56,time:0,sended:1500,err:0 
57,time:0,sended:1500,err:0 
58,time:0,sended:1500,err:0 
59,time:0,sended:1500,err:0 
60,time:0,sended:1500,err:0 
61,time:0,sended:1500,err:0 
62,time:0,sended:1500,err:0 
63,time:0,sended:1500,err:0 
64,time:0,sended:1500,err:0 
65,time:0,sended:1500,err:0 
66,time:0,sended:1500,err:0 
67,time:0,sended:1500,err:0 
68,time:0,sended:1500,err:0 
69,time:0,sended:1500,err:0 
70,time:0,sended:1500,err:0 
71,time:0,sended:1500,err:0 
72,time:0,sended:1500,err:0 
73,time:0,sended:1500,err:0 
74,time:0,sended:1500,err:0 
75,time:0,sended:1500,err:0 
76,time:0,sended:1500,err:0 
77,time:0,sended:1500,err:0 
78,time:0,sended:1500,err:0 
79,time:0,sended:1500,err:0 
80,time:0,sended:1500,err:0 
81,time:0,sended:1500,err:0 
82,time:0,sended:1500,err:0 
83,time:0,sended:1500,err:0 
84,time:0,sended:1500,err:0 
85,time:0,sended:1500,err:0 
86,time:0,sended:1500,err:0 
87,time:0,sended:1500,err:0 
88,time:0,sended:1500,err:0 
89,time:0,sended:1500,err:0 
90,time:0,sended:1500,err:0 
91,time:0,sended:1500,err:0 
92,time:0,sended:1500,err:0 
93,time:0,sended:1500,err:0 
94,time:0,sended:1500,err:0 
95,time:0,sended:1500,err:0 
96,time:0,sended:1500,err:0 
97,time:0,sended:1500,err:0 
98,time:0,sended:1500,err:0 
99,time:0,sended:1500,err:0 
100,time:0,sended:1500,err:0 
101,time:0,sended:1500,err:0 
102,time:0,sended:1500,err:0 
103,time:0,sended:1500,err:0 
104,time:0,sended:1500,err:0 
105,time:0,sended:1500,err:0 
106,time:0,sended:1500,err:0 
107,time:0,sended:1500,err:0 
108,time:0,sended:1500,err:0 
109,time:0,sended:1500,err:0 
110,time:0,sended:1500,err:0 
111,time:0,sended:1500,err:0 
112,time:0,sended:1500,err:0 
113,time:0,sended:1500,err:0 
114,time:0,sended:1500,err:0 
115,time:0,sended:1500,err:0 
116,time:0,sended:1500,err:0 
117,time:0,sended:1500,err:0 
118,time:0,sended:1500,err:0 
119,time:0,sended:1500,err:0 
120,time:0,sended:1500,err:0 
121,time:0,sended:1500,err:0 
122,time:0,sended:1500,err:0 
123,time:0,sended:1500,err:0 
124,time:0,sended:1500,err:0 
125,time:1999,sended:340,err:0 //這里出現了發送不全
126,time:0,sended:1500,err:0 
127,time:0,sended:1500,err:0 
128,time:0,sended:1500,err:0 
129,time:0,sended:1500,err:0 
130,time:0,sended:1500,err:0 
131,time:0,sended:1500,err:0 
132,time:0,sended:1500,err:0 
133,time:0,sended:1500,err:0 
134,time:0,sended:1500,err:0 
135,time:0,sended:1500,err:0 
136,time:0,sended:1500,err:0 
137,time:0,sended:1500,err:0 
138,time:0,sended:1500,err:0 
139,time:0,sended:1500,err:0 
140,time:0,sended:1500,err:0 
141,time:0,sended:1500,err:0 
142,time:0,sended:1500,err:0 
143,time:0,sended:1500,err:0 
144,time:0,sended:1500,err:0 
145,time:0,sended:1500,err:0 
146,time:0,sended:1500,err:0 
147,time:2000,sended:1268,err:0 
148,time:2000,sended:-1,err:11

同樣send也會出現和recv一樣,會有發送不全的現象.

posted on 2012-04-27 09:14 天下 閱讀(41120) 評論(0)  編輯 收藏 引用 所屬分類: Socket

<2013年6月>
2627282930311
2345678
9101112131415
16171819202122
23242526272829
30123456

導航

統計

常用鏈接

留言簿(4)

隨筆分類(378)

隨筆檔案(329)

鏈接

最新隨筆

搜索

最新評論

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            乱码第一页成人| 日韩性生活视频| 亚洲小视频在线观看| 一区二区三区四区在线| 国产日韩专区在线| 女女同性精品视频| 欧美理论大片| 欧美在线一二三区| 免费的成人av| 午夜精品三级视频福利| 老司机午夜精品| 亚洲欧美日韩视频一区| 久久手机免费观看| 亚洲男女自偷自拍| 欧美www视频在线观看| 欧美一区二区三区播放老司机| 久久亚裔精品欧美| 欧美一级午夜免费电影| 欧美国产精品v| 久久狠狠婷婷| 欧美体内谢she精2性欧美| 欧美+亚洲+精品+三区| 国产精品美女一区二区在线观看| 欧美成人综合网站| 国产精品一区在线观看你懂的| 欧美激情一区二区三区在线视频 | 99国产精品久久久| 久久高清福利视频| 午夜日韩在线观看| 欧美日韩国产免费| 亚洲黄页一区| 伊人一区二区三区久久精品| 亚洲午夜电影网| 一本色道久久综合精品竹菊 | 亚洲一区在线观看视频| 免费观看日韩av| 麻豆av福利av久久av| 国产午夜久久久久| 亚洲欧美日韩精品久久久| 亚洲香蕉成视频在线观看| 欧美激情视频一区二区三区在线播放| 噜噜噜在线观看免费视频日韩| 国产精品日本精品| 亚洲一区二区av电影| 亚洲自拍另类| 国产精品久久久久91| 欧美偷拍另类| 亚洲人成网站精品片在线观看 | 亚洲激情偷拍| 在线欧美一区| 永久免费精品影视网站| 在线观看的日韩av| 91久久精品久久国产性色也91 | 午夜老司机精品| 久久精品国产亚洲一区二区三区| 老**午夜毛片一区二区三区| 免费成人av在线| 亚洲毛片在线看| 午夜视黄欧洲亚洲| 欧美紧缚bdsm在线视频| 国产精品理论片| 日韩西西人体444www| 久久爱www久久做| 亚洲国产美女久久久久| 中文一区二区在线观看| 久久综合999| 国产一级揄自揄精品视频| 夜夜狂射影院欧美极品| 久色成人在线| 欧美在线国产精品| 国产精品久久综合| 亚洲欧美日韩网| 亚洲国产欧美精品| 欧美中文字幕精品| 国产欧美日韩亚洲| 欧美亚洲专区| 亚洲欧美电影院| 国产精品日韩欧美大师| 亚洲小说欧美另类婷婷| 99精品欧美一区二区三区| 欧美激情视频免费观看| 91久久亚洲| 亚洲精品一区二区三区樱花| 免费在线观看日韩欧美| 亚洲一区二区三区在线看| 欧美a级片网站| 亚洲精品久久久久久久久久久| 欧美91视频| 欧美激情影音先锋| 亚洲社区在线观看| 中文欧美字幕免费| 国产乱码精品一区二区三区不卡| 一区二区日韩| 亚洲欧美另类在线| 永久免费精品影视网站| 亚洲国产精品嫩草影院| 欧美日韩一区精品| 性亚洲最疯狂xxxx高清| 久久夜色精品国产噜噜av| 9色porny自拍视频一区二区| 亚洲性视频网站| 在线日韩av片| 在线视频你懂得一区| 狠狠色狠狠色综合人人| 亚洲精品乱码久久久久久蜜桃91| 国产精品免费看久久久香蕉| 久久久国产精彩视频美女艺术照福利| 久久夜色精品亚洲噜噜国产mv| 一区二区欧美视频| 久久精品国亚洲| 亚洲一区二区成人| 欧美好骚综合网| 美女任你摸久久| 国产精品亚洲一区| 亚洲精品国产精品国自产观看浪潮| 国产欧美日韩另类视频免费观看| 亚洲国产日韩欧美综合久久| 国产一区二区三区久久精品| 一区二区三区视频在线播放| 亚洲人成网站影音先锋播放| 欧美影视一区| 性久久久久久久久久久久| 欧美精品激情在线| 亚洲激情成人| 亚洲欧洲偷拍精品| 老司机免费视频一区二区| 蜜桃精品一区二区三区| 国内精品免费午夜毛片| 欧美一级片一区| 久久精品一级爱片| 狠狠色综合播放一区二区| 久久狠狠亚洲综合| 久久国产一区二区| 久久久精品tv| 一区二区在线视频观看| 久久成人资源| 亚洲国产三级| 亚洲欧美激情在线视频| 国产九区一区在线| 欧美尤物一区| 91久久精品视频| 亚洲欧美激情一区| 国语自产在线不卡| 欧美日韩视频一区二区三区| 亚洲伊人伊色伊影伊综合网| 久久人人97超碰国产公开结果| 精品不卡一区| 欧美三级资源在线| 欧美伊人久久久久久久久影院 | 国产精品免费观看在线| 香蕉久久夜色精品国产使用方法| 欧美成va人片在线观看| 亚洲一级片在线观看| 亚洲国产裸拍裸体视频在线观看乱了| 欧美另类人妖| 久久久久免费| 午夜精品一区二区三区在线播放| 欧美成人一区二免费视频软件| 亚洲美女中文字幕| 影音先锋一区| 国产精品视频一二| 欧美日韩1080p| 久久亚洲精品中文字幕冲田杏梨| aa国产精品| 国产亚洲成人一区| 欧美黄在线观看| 欧美国产免费| 欧美a一区二区| 久久久亚洲成人| 久久久久欧美| 欧美一区二区三区视频| 午夜久久电影网| 亚洲欧美综合另类中字| 999亚洲国产精| 日韩视频免费在线| 亚洲成色777777女色窝| 乱人伦精品视频在线观看| 欧美资源在线| 久久一区二区三区四区| 久久亚洲精品视频| 欧美福利视频| 在线视频精品一区| 亚洲欧美日韩国产成人| 亚洲综合导航| 久久精品国产69国产精品亚洲| 久久国产日韩欧美| 亚洲国产专区校园欧美| 日韩特黄影片| 午夜精品视频在线观看| 蜜臀99久久精品久久久久久软件| 免费在线观看精品| 国产精品日韩| 在线观看国产一区二区| 亚洲图片在线观看| 久久久久久久尹人综合网亚洲| 欧美国产日韩精品免费观看| 亚洲精品社区| 欧美在线看片a免费观看| 免费在线欧美视频| 国语自产精品视频在线看一大j8 |