Socket
Socket 中的 read()、write() 函數(shù)
ssize_tread(intfd,void*buf,size_tcount);ssize_twrite(intfd,constvoid*buf,size_tcount);
read()
read 函數(shù)是負(fù)責(zé)從 fd 中讀取內(nèi)容。
當(dāng)讀成功時,read 返回實際所讀的字節(jié)數(shù)。
如果返回的值是 0 表示已經(jīng)讀到文件的結(jié)束了,小于 0 表示出現(xiàn)了錯誤。
如果錯誤為 EINTR 說明讀是由中斷引起的;如果是 ECONNREST 表示網(wǎng)絡(luò)連接出了問題。
write()
write 函數(shù)將 buf 中的 nbytes 字節(jié)內(nèi)容寫入文件描述符 fd。
成功時返回寫的字節(jié)數(shù)。失敗時返回 -1,并設(shè)置 errno 變量。
在網(wǎng)絡(luò)程序中,當(dāng)我們向套接字文件描述符寫時有倆種可能。
(1)write 的返回值大于 0,表示寫了部分或者是全部的數(shù)據(jù)。
(2)返回的值小于 0,此時出現(xiàn)了錯誤。
如果錯誤為 EINTR 表示在寫的時候出現(xiàn)了中斷錯誤;如果為 EPIPE 表示網(wǎng)絡(luò)連接出現(xiàn)了問題(對方已經(jīng)關(guān)閉了連接)。
Socket 中 TCP 的三次握手建立連接
我們知道 TCP 建立連接要進行 “三次握手”,即交換三個分組。大致流程如下:
客戶端向服務(wù)器發(fā)送一個 SYN J
服務(wù)器向客戶端響應(yīng)一個 SYN K,并對 SYN J 進行確認(rèn) ACK J+1
客戶端再想服務(wù)器發(fā)一個確認(rèn) ACK K+1
只有就完了三次握手,但是這個三次握手發(fā)生在 Socket 的那幾個函數(shù)中呢?請看下圖:
從圖中可以看出:
(1)當(dāng)客戶端調(diào)用 connect 時,觸發(fā)了連接請求,向服務(wù)器發(fā)送了 SYN J 包,這時 connect 進入阻塞狀態(tài);
(2)服務(wù)器監(jiān)聽到連接請求,即收到 SYN J 包,調(diào)用 accept 函數(shù)接收請求向客戶端發(fā)送 SYN K ,ACK J+1,這時 accept 進入阻塞狀態(tài);
(3)客戶端收到服務(wù)器的 SYN K ,ACK J+1 之后,這時 connect 返回,并對 SYN K 進行確認(rèn);
(4)服務(wù)器收到 ACK K+1 時,accept 返回,至此三次握手完畢,連接建立。
Socket 中 TCP 的四次握手釋放連接
上面介紹了 socket 中 TCP 的三次握手建立過程,及其涉及的 socket 函數(shù)。現(xiàn)在我們介紹 socket 中的四次握手釋放連接的過程,請看下圖:
圖示過程如下:
某個應(yīng)用進程首先調(diào)用 close 主動關(guān)閉連接,這時 TCP 發(fā)送一個 FIN M;
另一端接收到 FIN M 之后,執(zhí)行被動關(guān)閉,對這個 FIN 進行確認(rèn)。它的接收也作為文件結(jié)束符傳遞給應(yīng)用進程,因為 FIN 的接收意味著應(yīng)用進程在相應(yīng)的連接上再也接收不到額外數(shù)據(jù);
一段時間之后,接收到文件結(jié)束符的應(yīng)用進程調(diào)用 close 關(guān)閉它的 socket。這導(dǎo)致它的 TCP 也發(fā)送一個 FIN N;
接收到這個 FIN 的源發(fā)送端 TCP 對它進行確認(rèn)。
這樣每個方向上都有一個 FIN 和 ACK。
————
今天的分享就到這里了,大家要好好學(xué)C++喲~
責(zé)任編輯:haq
-
Linux
+關(guān)注
關(guān)注
87文章
11335瀏覽量
210086 -
編程
+關(guān)注
關(guān)注
88文章
3635瀏覽量
93892 -
C++
+關(guān)注
關(guān)注
22文章
2114瀏覽量
73771
原文標(biāo)題:C++基礎(chǔ)語法梳理:網(wǎng)絡(luò)編程丨Socket
文章出處:【微信號:cyuyanxuexi,微信公眾號:C語言編程學(xué)習(xí)基地】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。
發(fā)布評論請先 登錄
相關(guān)推薦
評論