作业:使用write和read完成文件的拷贝。
代码
#include <myhead.h>
int main(int argc, const char *argv[])
{
int fd = open("./1.txt",O_RDONLY);//已只读打开被拷贝文件
if(-1 == fd)
{
perror("open");
return -1;
}
int fd1 = open("./2.txt",O_WRONLY | O_CREAT | O_TRUNC,0664);//已只写方式打开
if(-1 == fd1)
{
perror("open");
return -1;
}
int i = lseek(fd,0,SEEK_END);//查看文件有多少字节内容
printf("%d\n",i);
lseek(fd,0,SEEK_SET);//恢复光标到开头
while(1)
{
char k[5]={0};
int len = read(fd,k,sizeof(k));//读取内容
write(fd1,k,len);
printf("%d\t%ld\n",len,sizeof(k));//写入内容
if(len != sizeof(k))//判断循环是否结束
{
break;
}
}
close(fd);
close(fd1);
//打印被拷贝文件内容
fd1 = open("./2.txt",O_RDONLY);
if(-1 == fd1)
{
perror("open");
return -1;
}
char a[32]= {0};
read(fd1,a,sizeof(a));
printf("%s",a);
return 0;
}
效果图
循环结束的条件结束判断:因为read函数返回值是读取到的内容大小,所以结束的条件结束当读取的内容大小和给的k的大小不一样就结束循环
一开始有考虑到如果刚好是这个读取的k的整数倍,那这循环不就结束不了
于是打印了len的变换,发现在全都读取完后他会再去读取,但读取不到内容了,所以最后len也不会和k的大小一样
每日整理
总结
**文章总结**本篇文章详细描述了一个使用C语言的`open`、`read`、`write`、`lseek`和`close`系统调用来完成文件拷贝的程序实例及其工作原理。具体步骤如下:
1. **文件打开**:
- 使用`open`系统调用以只读模式(`O_RDONLY`)打开源文件(`1.txt`),并将返回的文件描述符存储在`fd`变量中。
- 以只写、创建并截断(`O_WRONLY | O_CREAT | O_TRUNC`)模式打开目标文件(或创建新文件)`2.txt`,并设置权限为`0664`。将返回的文件描述符存储在`fd1`变量中。
2. **读取与写入文件内容**:
- 通过`lseek`将源文件`fd`的文件指针偏移设置为文件的末尾(仅用于确定文件大小,但实际操作时需将其重置为文件开头)。
- 使用`lseek`将文件指针重新设置到文件的起始位置。
- 进入一个循环,不断通过`read`函数从源文件读取数据到数组`k`中,然后利用`write`将这些数据写入到目标文件。这里采用固定大小数组`k`(大小为5个字节)进行读写操作。
- 循环结束的条件是`read`函数的返回值(即实际读取的字节数)小于数组`k`的大小,意味着已经到达了文件的末尾。
3. **关闭文件描述符**:
- 完成文件拷贝后,使用`close`函数关闭两个文件描述符`fd`和`fd1`。
4. **验证拷贝内容**(额外):
- 为了验证文件拷贝的成功,文章还展示了如何重新以只读模式打开目标文件,并读取部分内容打印到标准输出进行验证。
**关键点解析**:
- 循环结束的条件主要依赖于`read`函数返回的读取字节数与指定大小的比较。当文件末尾被到达时,`read`函数返回的实际字节数会小于指定的数组大小,从而触发循环退出条件。
- 打印`len`(读取到的字节数)和`sizeof(k)`(尝试读取的字节数)有助于理解程序逻辑,特别是确保即便在文件大小是`k`的整数倍时也能正确结束循环(因为文件末尾的读取会遇到EOF,导致`read`返回值小于`sizeof(k)`)。
**每日整理**部分提及了对文件拷贝机制及产品实现细节的理解深化,特别是关于如何确保数据完整性和循环终止条件的正确处理。