完整的讀寫函式
一旦我們建立了連線,我們的下一步就是進行通訊了.在linux下面把我們前面建立的通道 看成是檔案描述符,這樣伺服器端和客戶端進行通訊時候,只要往檔案描述符裡面讀寫東西了. 就象我們往檔案讀寫一樣.
1、寫函式write
ssize_t write(int fd,const void *buf,size_t nbytes)
write函式將buf中的nbytes位元組內容寫入檔案描述符fd.成功時返回寫的位元組數.失敗時返回-1. 並設定errno變數. 在網路程式中,當我們向套接字檔案描述符寫時有倆種可能.
(1)write的返回值大於0,表示寫了部分或者是全部的資料.
(2)返回的值小於0,此時出現了錯誤.我們要根據錯誤型別來處理.
如果錯誤為eintr表示在寫的時候出現了中斷錯誤.
如果為epipe表示網路連線出現了問題(對方已經關閉了連線).
為了處理以上的情況,我們自己編寫乙個寫函式來處理這幾種情況.
int my_write(int fd,void *buffer,int length)
bytes_left-=written_bytes;
ptr+=written_bytes; /* 從剩下的地方繼續寫 */
} return(0);
} 2、讀函式read
ssize_t read(int fd,void *buf,size_t nbyte)
read函式是負責從fd中讀取內容.當讀成功時,read返回實際所讀的位元組數,如果返回的值是0 表示已經讀到檔案的結束了,小於0表示出現了錯誤.如果錯誤為eintr說明讀是由中斷引起的, 如果是econnrest表示網路連線出了問題. 和上面一樣,我們也寫乙個自己的讀函式.
int my_read(int fd,void *buffer,int length)
else if(bytes_read==0)
break;
bytes_left-=bytes_read;
ptr+=bytes_read;
} return(length-bytes_left);
} 3、資料的傳遞
有了上面的兩個函式,我們就可以向客戶端或者是服務端傳遞資料了.比如我們要傳遞乙個結構.可以使用如下方式
/* 客戶端向服務端寫 */
struct my_struct my_struct_client;
write(fd,(void *)&my_struct_client,sizeof(struct my_struct);
/* 服務端的讀*/
char buffer[sizeof(struct my_struct)];
struct *my_struct_server;
read(fd,(void *)buffer,sizeof(struct my_struct));
my_struct_server=(struct my_struct *)buffer;
在網路上傳遞資料時我們一般都是把資料轉化為char型別的資料傳遞.接收的時候也是一樣的 注意的是我們沒有必要在網路上傳遞指標(因為傳遞指標是沒有任何意義的,我們必須傳遞指標所指向的內容)
Linux系統程式設計 網路程式設計基礎(三)
若在網路中,需要使客戶端連線的位址為乙個有效的ip位址,這樣就能在兩台計算機之間通訊。除ip位址外,計算機名也可用來代表一台網路中的計算機。通過訪問主機資料庫實現的。伺服器資料庫介面函式在標頭檔案netdb.h中定義。與此相關的函式有gethostbyaddr 和gethostbyname 兩個,一...
網路程式設計 網路基礎(三)
tcp ip協議規定,網路資料必須採用大端位元組序,即低位址高位元組 大端 低位址存到高位,高位址存到低位 小端 低位址存到低位,高位址存到高位 為了使網路具有可移植性,使同樣的c 在大端小端計算機上編譯後都能正確執行,可以呼叫以下函式做網路位元組序和主機位元組序的轉換 h表示host n表示net...
linux網路程式設計基礎 網路基礎
客戶機 client 伺服器 server 模式。需要在通訊兩端各自部署客戶機和伺服器來完成資料通訊。瀏覽器 browser 伺服器 server 模式。只需在一端部署伺服器,而另外一端使用每台pc都預設配置的瀏覽器即可完成資料的傳輸。c s模式 優點缺點 資料快取本地,效率高 工作量大,開發周期更...