函数read、write
write
函数说明:write()会把参数buf所指的内存写入count个字节到参数放到所指的文件内。write成功返回,只是buf中的数据被复制到了kernel中的TCP发送缓冲区。
#include<unistd.h>
ssize_t write (int fd, const void * buf, size_t count);
返回值:如果顺利write()会返回实际写入的字节数。当有错误发生时则返回-1,错误代码存入errno中。
附加说明:
1、write()函数返回值一般无0,只有当如下情况发生时才会返回0:write(fp, p1+len, (strlen(p1)-len)中第三参数为0,此时write()什么也不做,只返回0。
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中数据的大小,以免出现错误。
测试程序
应证了附加说明第一条
#include<string.h>
#include<stdio.h>
#include<fcntl.h>
#include<sys/stat.h>
#include<unistd.h>
int main()
{
char *p1 = "This is c test code";
int len = 0;
int fp = open("test",O_RDWR | O_CREAT);
while(1){
int n;
if((n=write(fp,p1+len,(strlen(p1)-len)))==0)
{
printf("n=%d\n",n);
break;
}
len += n;
}
return 0;
}
read
#include<unistd.h>
ssize_t read(int fd, void * buf, size_t count);
read()会把参数fd所指的文件传送count 个字节到buf 指针所指的内存中。
参数count是请求读取的字节数,读上来的数据保存在缓冲区buf中,同时文件的当前读写位置向后移。注意这个读写位置和使用C标准I/O库时的读写位置有可能不同,这个读写位置是记在内核中的,而使用C标准I/O库时的读写位置是用户空间I/O缓冲区中的位置。比如用fgetc读一个字节,
fgetc有可能从内核中预读1024个字节到I/O缓冲区中,再返回第一个字节,这时该文件在内核中记录的读写位置是1024,而在FILE结构体中记录的读写位置是1。注意返回值类型是ssize_t,表示有符号的size_t,这样既可以返回正的字节数、0(表示到达文件末尾)也可以返回负值-1(表示出错)
read函数返回时,返回值说明了buf中前多少个字节是刚读上来的。
测试程序
#include<sys/stat.h>
#include<unistd.h>
#include<stdio.h>
#include<fcntl.h>
#include<stdlib.h>
#define BUFFSIZE 4096
int main()
{
int n;
char buf[BUFFSIZE];
int fd = open("test",O_RDONLY |O_CREAT);
if(fd==-1){
printf("打开失败");
exit(0);
}
while((n=read(fd,buf,BUFFSIZE))>0){
printf("read success\n");
printf("%s",buf);
}
return 0;
}