前面的程式,不管伺服器端還是客戶端,都有乙個問題,就是處理完乙個請求立即退出了,沒有太大的實際意義。能不能像web伺服器那樣一直接受客戶端的請求呢?能,使用 while 迴圈即可。
修改前面的回聲程式,使伺服器端可以不斷響應客戶端的請求。
伺服器端 server.cpp:
#include
#include
#pragma
comment
(lib,
"ws2_32.lib"
)//載入 ws2_32.dll
#define buf_size 100
intmain();
//緩衝區
while(1
)//關閉套接字
closesocket
(servsock);
//終止 dll 的使用
wsacleanup
();return0;
}
客戶端 client.cpp:
#include
#include
#include
#pragma
comment
(lib,
"ws2_32.lib"
)//載入 ws2_32.dll
#define buf_size 100
intmain();
char bufrecv[buf_size]=;
while(1
)wsacleanup
();//終止使用 dll
return0;
}
先執行伺服器端,再執行客戶端,結果如下:
input a string: c language
message form server: c language
input a string: c語言中文網
message form server: c語言中文網
input a string: 學習c/c++程式設計的好**
message form server: 學習c/c++程式設計的好**
while(1) 讓**進入死迴圈,除非使用者關閉程式,否則伺服器端會一直監聽客戶端的請求。客戶端也是一樣,會不斷向伺服器發起連線。
需要注意的是:server.cpp 中呼叫 closesocket() 不僅會關閉伺服器端的 socket,還會通知客戶端連線已斷開,客戶端也會清理 socket 相關資源,所以 client.cpp 中需要將 socket() 放在 while 迴圈內部,因為每次請求完畢都會清理 socket,下次發起請求時需要重新建立。後續我們會進行詳細講解。
4 3 實現迭代伺服器端 客戶端
標題寫的是 實現迭代伺服器端 客戶端 實際上就是實現了乙個有echo功能的,單使用者服務的 單程序 執行緒 伺服器端,再配上乙個客戶端。伺服器端的說明 該伺服器端是僅面向單使用者的,處理有限次使用者任務的。伺服器端僅僅是將使用者由tcp傳送來的資訊 上限1024bytes 回顯至客戶端 與 tcp ...
網路程式設計 實現迭代回聲伺服器端 客戶端
1.直接跳轉到linux端 2.直接跳轉到windows端 掌握tcp套接字工作原理。在linux和windows作業系統上編寫迭代伺服器端 客戶端。讓伺服器端以迭代方式執行,為多個客戶端提供回聲服務。1 在linux作業系統上編寫程式,實現迭代回聲伺服器端 客戶端 1 改進實驗一中實現的hello...
伺服器端渲染和客戶端渲染
網際網路早期,使用者使用瀏覽器瀏覽的都是一些沒有複雜邏輯的 簡單的頁面,這些頁面都是在後端將html拼接好的然後將之返回給前端完整的html檔案,瀏覽器拿到這個html檔案之後就可以直接解析展示了,而這也就是所謂的伺服器端渲染了。而隨著前端頁面的複雜性提高,前端就不僅僅是普通的頁面展示了,而可能新增...