1、write()
函數定義:ssize_t write (int fd, const void * buf, size_t count);
函數說明:write()會把參數buf所指的內存寫入count個字節到參數放到所指的文件內。
返回值:如果順利write()會返回實際寫入的字節數。當有錯誤發生時則返回-1,錯誤代碼存入errno中。
附加說明:
(1)write()函數返回值一般無0,只有當如下情況發生時才會返回0:write(fp, p1+len, (strlen(p1)-len)中第三參數為0,此時write()什么也不做,只返回0。man手冊給出的write()返回值的說明如下:
(2)write()函數從buf寫數據到fd中時,若buf中數據無法一次性讀完,那么第二次讀buf中數據時,其讀位置指針(也就是第二個參數buf)不會自動移動,需要程序員編程控制,
而不是簡單的將buf首地址填入第二參數即可。如可按如下格式實現讀位置移動:write(fp, p1+len, (strlen(p1)-len)。 這樣write第二次循環時變會從p1+len處寫數據到fp, 之后的也
由此類推,直至(strlen(p1)-len變為0。
(3)在write一次可以寫的最大數據范圍內(貌似是BUFSIZ ,8192),第三參數count大小最好為buf中數據的大小,以免出現錯誤。(經過筆者再次試驗,write一次能夠寫入的並不只有8192這么多,筆者嘗試一次寫入81920000,結果也是可以,看來其一次最大寫入數據並不是8192,但內核中確實有BUFSIZ這個參數,具體指什么還有待研究)
以下通過一個例子具體說明write函數用法
#include
#include
#include
int main()
{
char *p1 = "This is a c test code";
volatile int len = 0;
int fp = open("/home/test.txt", O_RDWR|O_CREAT);
for(;;)
{
int n;
if((n=write(fp, p1+len, (strlen(p1)-len)))== 0) //if((n=write(fp, p1+len, 3)) == 0)
{ //strlen(p1) = 21
printf("n = %d \n", n);
break;
}
len+=n;
}
return 0;
}
此程序中的字符串"This is a c test code"有21個字符,經筆者親自試驗,若write時每次寫3個字節,雖然可以將p1中數據寫到fp中,但文件test.txt中會帶有很多亂碼。唯一正確的做法還是將第三參數設為(strlen(p1) - len,這樣當write到p1末尾時(strlen(p1) - len將會變為0,此時符合附加說明(1)中所說情況,write返回0, write結束。
2、read()
函數定義:ssize_t read(int fd, void * buf, size_t count);
函數說明:read()會把參數fd所指的文件傳送count 個字節到buf 指針所指的內存中。
返回值:返回值為實際讀取到的字節數, 如果返回0, 表示已到達文件尾或是無可讀取的數據。若參數count 為0, 則read()不會有作用並返回0。
注意:read時fd中的數據如果小於要讀取的數據,就會引起阻塞。
read的用法比write較為簡單,此處不敘述過多。由於筆者水平也有限,如果文中有謬誤之處還懇請諸位指出,以免誤導大家。