linux下的read和write函数,深入理解linux下write()和read()函數

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()返回值的說明如下:

a6823fcfa3906e3c3f7e6acb2fe13a8d.png

(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較為簡單,此處不敘述過多。由於筆者水平也有限,如果文中有謬誤之處還懇請諸位指出,以免誤導大家。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值