與是recv一樣,有收就會有發(fā),發(fā)送內(nèi)容對應send函數(shù),也是從服務端accept后或客戶端connect后就可以用的函數(shù),其說明如下:
函數(shù)功能:
發(fā)送服務端或客戶端的數(shù)據(jù)
頭文件:
#include <winsock2.h>
函數(shù)原型:
int send(int aID, const char *buf, int len, int flags);
返回值類型:
整型
返回值:
返回值小于0,socket報錯。返回值等于0對方調(diào)用了close API來關(guān)閉連接,返回值大于0成功,返回值為發(fā)送的的數(shù)據(jù)長度
參數(shù)說明:
第一個參數(shù)aID,表示連接成功的套接字描述符。
注意:這一步對于服務端而言是上一步accept的返回值;對于客戶端而言是connect的返回值,并非是第一步socket創(chuàng)建套接字的返回值,請大家理解不要搞混!
第二個參數(shù)buf為要發(fā)送的數(shù)據(jù)所在的緩沖區(qū)地址,即一個已經(jīng)存好內(nèi)容的字符數(shù)組
第三個參數(shù)len為要發(fā)送的數(shù)據(jù)的實際字節(jié)數(shù)+1。
第四個參數(shù)flags為發(fā)送數(shù)據(jù)時的附帶標記 ,一般情況下設置為0。但可以選擇下列設置:
MSG_DONTROUTE:表示不使用指定路由,對send、sendto有效
MSG_PEEK:對recv, recvfrom有效,表示讀出網(wǎng)絡數(shù)據(jù)后不清除已讀的數(shù)據(jù)
MSG_OOB:對發(fā)送接收都有效,表示發(fā)送或接受加急數(shù)據(jù)
調(diào)用send函數(shù)整體代碼的實現(xiàn):
char sendBuf[200];//定義一個數(shù)組用來保存發(fā)送的數(shù)據(jù) send(aID,sendBuf,strlen(sendBuf)+1,0);//用來發(fā)送服務端或客戶端的數(shù)據(jù)
與recv同樣,send函數(shù)缺省也是阻塞函數(shù),直到發(fā)送完畢或出錯才會返回。
需要注意,如果函數(shù)返回值與參數(shù)len不相等,則剩余未發(fā)送的信息需要再次發(fā)送。
C語言網(wǎng)提供由在職研發(fā)工程師或ACM藍橋杯競賽優(yōu)秀選手錄制的視頻教程,并配有習題和答疑,點擊了解:
一點編程也不會寫的:零基礎(chǔ)C語言學練課程
解決困擾你多年的C語言疑難雜癥特性的C語言進階課程
從零到寫出一個爬蟲的Python編程課程
只會語法寫不出代碼?手把手帶你寫100個編程真題的編程百練課程
信息學奧賽或C++選手的 必學C++課程
藍橋杯ACM、信息學奧賽的必學課程:算法競賽課入門課程
手把手講解近五年真題的藍橋杯輔導課程