linux(ubuntu 9.10)下socket(tcp/ip)通信

參考了一些代碼,但是他們的代碼總是存在着這樣或者那樣的問題。

重寫了以下,運行成功。

運行服務端代碼後,運行客戶端,服務端會寫出連接來自哪裏。服務端無限服務,所以服務端結束的時候要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
 

 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章