后面的程序,不論效勞器端照樣客戶端,都有一個(gè)成績,就是處置完一個(gè)懇求立刻加入了,沒有太大的實(shí)踐意義。能不克不及像Web效勞器那樣不斷承受客戶端的懇求呢?能,運(yùn)用 while 輪回即可。
修正后面的反響程序,使效勞器端可以不時(shí)呼應(yīng)客戶端的懇求。
效勞器端 server.cpp:
創(chuàng)新互聯(lián)主要從事成都做網(wǎng)站、成都網(wǎng)站制作、網(wǎng)頁設(shè)計(jì)、企業(yè)做網(wǎng)站、公司建網(wǎng)站等業(yè)務(wù)。立足成都服務(wù)秦皇島,10多年網(wǎng)站建設(shè)經(jīng)驗(yàn),價(jià)格優(yōu)惠、服務(wù)專業(yè),歡迎來電咨詢建站服務(wù):13518219792
#include <stdio.h> #include <winsock2.h> #pragma comment (lib, "ws2_32.lib") //加載 ws2_32.dll #define BUF_SIZE 100 int main(){ WSADATA wsaData; WSAStartup( MAKEWORD(2, 2), &wsaData); //創(chuàng)立套接字 SOCKET servSock = socket(AF_INET, SOCK_STREAM, 0); //綁定套接字 sockaddr_in sockAddr; memset(&sockAddr, 0, sizeof(sockAddr)); //每一個(gè)字節(jié)都用0填充 sockAddr.sin_family = PF_INET; //運(yùn)用IPv4地址 sockAddr.sin_addr.s_addr = inet_addr("127.0.0.1"); //詳細(xì)的IP地址 sockAddr.sin_port = htons(1234); //端口 bind(servSock, (SOCKADDR*)&sockAddr, sizeof(SOCKADDR)); //進(jìn)入監(jiān)聽形態(tài) listen(servSock, 20); //接納客戶端懇求 SOCKADDR clntAddr; int nSize = sizeof(SOCKADDR); char buffer[BUF_SIZE] = {0}; //緩沖區(qū) while(1){ SOCKET clntSock = accept(servSock, (SOCKADDR*)&clntAddr, &nSize); int strLen = recv(clntSock, buffer, BUF_SIZE, 0); //接納客戶端發(fā)來的數(shù)據(jù) send(clntSock, buffer, strLen, 0); //將數(shù)據(jù)原樣前往 closesocket(clntSock); //封閉套接字 memset(buffer, 0, BUF_SIZE); //重置緩沖區(qū) } //封閉套接字 closesocket(servSock); //終止 DLL 的運(yùn)用 WSACleanup(); return 0; }
客戶端 client.cpp:
#include <stdio.h> #include <WinSock2.h> #include <windows.h> #pragma comment(lib, "ws2_32.lib") //加載 ws2_32.dll #define BUF_SIZE 100 int main(){ //初始化DLL WSADATA wsaData; WSAStartup(MAKEWORD(2, 2), &wsaData); //向效勞器提議懇求 sockaddr_in sockAddr; memset(&sockAddr, 0, sizeof(sockAddr)); //每一個(gè)字節(jié)都用0填充 sockAddr.sin_family = PF_INET; sockAddr.sin_addr.s_addr = inet_addr("127.0.0.1"); sockAddr.sin_port = htons(1234); char bufSend[BUF_SIZE] = {0}; char bufRecv[BUF_SIZE] = {0}; while(1){ //創(chuàng)立套接字 SOCKET sock = socket(PF_INET, SOCK_STREAM, IPPROTO_TCP); connect(sock, (SOCKADDR*)&sockAddr, sizeof(SOCKADDR)); //獲取用戶輸出的字符串并發(fā)送給效勞器 printf("Input a string: "); gets(bufSend); send(sock, bufSend, strlen(bufSend), 0); //接納效勞器傳回的數(shù)據(jù) recv(sock, bufRecv, BUF_SIZE, 0); //輸入接納到的數(shù)據(jù) printf("Message form server: %s\n", bufRecv); memset(bufSend, 0, BUF_SIZE); //重置緩沖區(qū) memset(bufRecv, 0, BUF_SIZE); //重置緩沖區(qū) closesocket(sock); //封閉套接字 } WSACleanup(); //終止運(yùn)用 DLL return 0; }
先運(yùn)轉(zhuǎn)效勞器端,再運(yùn)轉(zhuǎn)客戶端,后果如下:
Input a string: c language
Message form server: c language
Input a string: C言語中文網(wǎng)
Message form server: C言語中文網(wǎng)
Input a string: 進(jìn)修C/C++編程的好網(wǎng)站
Message form server: 進(jìn)修C/C++編程的好網(wǎng)站
while(1) 讓代碼進(jìn)入死輪回,除非用戶封閉程序,不然效勞器端會(huì)不斷監(jiān)聽客戶端的懇求。客戶端也是一樣,會(huì)不時(shí)向效勞器提議銜接。
需求留意的是:server.cpp 中挪用 closesocket() 不只會(huì)封閉效勞器端的 socket,還會(huì)告訴客戶端銜接已斷開,客戶端也會(huì)清算 socket 相干資本,所以 client.cpp 中需求將 socket() 放在 while 輪回外部,由于每次懇求終了都邑清算 socket,下次提議懇求時(shí)需求從新創(chuàng)立。后續(xù)我們會(huì)停止具體解說。
新聞名稱:完成迭代效勞器端和客戶端
鏈接地址:http://muchs.cn/article2/ghgiic.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供商城網(wǎng)站、App設(shè)計(jì)、建站公司、做網(wǎng)站、域名注冊、
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)