c語(yǔ)言socket多線程編程限制客戶端連接數(shù)
先上一些多線程需要使用的函數(shù)定義:
DWORD WINAPI ProcessClientRequests(LPVOID lpParam) //新線程將會(huì)執(zhí)行的函數(shù)定義
{
return 0;
}
HANDLE handler=CreateThread(NULL, 0, ProcessClientRequests, &clientsocket, 0, NULL); //這里比較簡(jiǎn)單,&clientsocket是個(gè)指針,是從主線程傳入新線程的參數(shù)
WaitForMultipleObjects(MAXCLIENTS, threads, TRUE, INFINITE); //用來(lái)阻塞主線程,直到所有創(chuàng)建的子線程都完成任務(wù)為止,才繼續(xù)執(zhí)行后面的代碼
for(int i=0;i<MAXCLIENTS; i++)
{
CloseHandle(threads[i]); //創(chuàng)建的每個(gè)子線程的HANDLE都會(huì)被保存在HANDLE數(shù)組中,這個(gè)函數(shù)用于關(guān)閉各個(gè)handle所對(duì)應(yīng)的線程空間
}
服務(wù)器端程序
主線程代碼如下:
#define MAXCLIENTS 3 //宏定義,最多3個(gè)客戶端連接
int main()
{
WSADATA wsaData;
WSAStartup(MAKEWORD(2, 2), &wsaData);
HANDLE threads[MAXCLIENTS];
SOCKET s=socket(PF_INET, SOCK_STREAM, IPPROTO_TCP);
sockaddr_in sockaddr;
sockaddr.sin_family=PF_INET;
sockaddr.sin_addr.S_un.S_addr=inet_addr("127.0.0.1");
sockaddr.sin_port=htons(9000);
bind(s, (SOCKADDR*)&sockaddr, sizeof(SOCKADDR));
listen(s, 1);
printf("listening on port [%d].\n", 9000);
int existingClientCount=0;
while(TRUE)
{
SOCKADDR clientAddr;
int size=sizeof(SOCKADDR);
SOCKET clientsocket;
clientsocket=accept(s, &clientAddr, &size);
printf("***SYS*** New client touched.\n");
if(existingClientCount<MAXCLIENTS) //判斷是否已經(jīng)超出最大連接數(shù)了
{
threads[existingClientCount++]=CreateThread(NULL, 0, ProcessClientRequests, &clientsocket, 0, NULL); //啟動(dòng)新線程,并且將socket傳入
}
else
{
char* msg="Exceeded Max incoming requests, will refused this connect!\r\n";
send(clientsocket, msg, strlen(msg)+sizeof(char), NULL); //發(fā)送拒絕連接消息給客戶端
printf("***SYS*** REFUSED.\n");
closesocket(clientsocket); //釋放資源
break;
}
}
printf("Maximize clients occurred for d%.\r\n", MAXCLIENTS);
WaitForMultipleObjects(MAXCLIENTS, threads, TRUE, INFINITE); //等待所有子線程,直到完成為止
closesocket(s);
for(int i=0;i<MAXCLIENTS; i++)
{
CloseHandle(threads[i]); //清理線程資源
}
WSACleanup();
printf("Cleared all.\r\n");
getchar();
exit(0);
}
子線程函數(shù)定義
DWORD WINAPI ProcessClientRequests(LPVOID lpParam)
{
SOCKET* clientsocket=(SOCKET*)lpParam; //這里需要強(qiáng)制轉(zhuǎn)換,注意:指針類型的
char* msg="Hello, my client.\r\n";
send(*clientsocket, msg, strlen(msg)+sizeof(char), NULL);
printf("***SYS*** HELLO.\n");
while(TRUE)
{
char buffer[MAXBYTE]={0};
recv(*clientsocket, buffer, MAXBYTE, NULL);
if(strcmp(buffer, "exit")==0)
{
char* msg_bye="Bye.\r\n";
send(*clientsocket, msg_bye, strlen(msg_bye)+sizeof(char), NULL);
break;
}
printf("***Client*** %s\n", buffer);
}
closesocket(*clientsocket);
return 0;
}
相關(guān)文章
C語(yǔ)言項(xiàng)目小學(xué)生數(shù)學(xué)考試系統(tǒng)參考
今天小編就為大家分享一篇關(guān)于C語(yǔ)言項(xiàng)目小學(xué)生數(shù)學(xué)考試系統(tǒng)參考,小編覺(jué)得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來(lái)看看吧2019-02-02
C語(yǔ)言報(bào)錯(cuò):Buffer Overflow的原因和解決辦法
Buffer Overflow是C語(yǔ)言中常見(jiàn)且危險(xiǎn)的內(nèi)存錯(cuò)誤之一,它通常在程序試圖向緩沖區(qū)(如數(shù)組或內(nèi)存塊)寫入超過(guò)其容量的數(shù)據(jù)時(shí)發(fā)生,本文將詳細(xì)介紹Buffer Overflow的產(chǎn)生原因,提供多種解決方案,需要的朋友可以參考下2024-07-07
C語(yǔ)言用棧和隊(duì)列實(shí)現(xiàn)的回文檢測(cè)功能示例
這篇文章主要介紹了C語(yǔ)言用棧和隊(duì)列實(shí)現(xiàn)的回文檢測(cè)功能,結(jié)合具體實(shí)例形式分析了C語(yǔ)言棧和隊(duì)列的定義及使用棧和隊(duì)列進(jìn)行回文檢測(cè)的操作技巧,需要的朋友可以參考下2017-06-06

