socket api中send()和recv()函数工作原理与要点
生活随笔
收集整理的這篇文章主要介紹了
socket api中send()和recv()函数工作原理与要点
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
send()和recv()函數是網絡編程中經常使用到的函數,下面詳細的比較兩者的不同之處
send函數工作原理:
??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)???
recv函數工作原理:
???recv先檢查套接字s的接收緩沖區,如果s接收緩沖區中沒有數據或者協議正在接收數據,那么recv就一直等待,直到協議把數據接收完畢。當協議把數據接收完畢,recv函數就把s的接收緩沖中的數據copy到buf中(注意協議接收到的數據可能大于buf的長度,所以在這種情況下要調用幾次recv函數才能把s的接收緩沖中的數據copy完。recv函數僅僅是copy數據,真正的接收數據是協議來完成的),recv函數返回其實際copy的字節數。如果recv在copy時出錯,那么它返回SOCKET_ERROR;如果recv函數在等待協議接收數據時網絡中斷了,那么它返回0?。? 對方優雅的關閉socket并不影響本地recv的正常接收數據;如果協議緩沖區內沒有數據,recv返回0,指示對方關閉;如果協議緩沖區有數據,則返回對應數據(可能需要多次recv),在最后一次recv時,返回0,指示對方關閉。
要點:
在進行TCP協議傳輸的時候,要注意數據流傳輸的特點,recv和send不一定是一一對應的(一般情況下是一一對應),也就是說并不是send一次,就一定recv一次就接收完,有可能send一次,recv多次才接收完,也可能send多次,一次recv就接收完了。TCP協議會保證數據的有序完整的傳輸,但是如何去正確完整的處理每一條信息,是程序員的事情。
例如:服務器在循環recv,recv的緩沖區大小為100byte,客戶端在循環send,每次send 6byte數據,則recv每次收到的數據可能為6byte,12byte,18byte,這是隨機的,編程的時候注意正確的處理。
???????? 創作挑戰賽新人創作獎勵來咯,堅持創作打卡瓜分現金大獎總結
以上是生活随笔為你收集整理的socket api中send()和recv()函数工作原理与要点的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: Redis之整数集合intset
- 下一篇: 敏感词过滤算法的实现