參考了一些代碼,但是他們的代碼總是存在着這樣或者那樣的問題。
重寫了以下,運行成功。
運行服務端代碼後,運行客戶端,服務端會寫出連接來自哪裏。服務端無限服務,所以服務端結束的時候要Ctrl+z
其中netdb.h中包含着sockaddr_in 等這一類的數據類型
其中的
fprintf(stderr,xx);
用來向終端輸出錯誤信息stderr 標準輸出(設備)文件的意思
int shutdown(int sockfd,int how);
Sockfd是需要關閉的socket的描述符。參數 how允許爲shutdown操作選擇以下幾種方式:
·0-------不允許繼續接收數據
·1-------不允許繼續發送數據
·2-------不允許繼續發送和接收數據,
客戶端代碼
()函數原型爲:
int sendto(int sockfd, const void *msg,int len,unsigned int flags,const struct sockaddr *to, int tolen);
該函數比send()函數多了兩個參
服務端代碼
同時關於fork的說明,fork創建一個父進程的副本,但是卻不盡相同。
fork函數返回兩個值,一個是返回到子進程,得到一個0的值
另一個是返回到父進程,得到的是子進程的id,這樣父子進程就可以分別執行不同的任務,如果分配不成功,則返回父進程-1
例如,執行如下代碼
將得到
this is the father process3112
and it's child threadid is3113
thread 3113 threadid is 0 is running