版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/qq_39776901/article/details/78635262
#include <stdio.h>
#include <sys/stat.h>
#include <fcntl.h>
#define BUFSIZE 512
void copy(char *from,char *to)
{
//定义两个整型变量fromfd,tofd
int fromfd = -1,tofd = -1;
//定义ssize_t类型变量nread
ssize_t nread;
//定义缓冲区buf,大小512
char buf[BUFSIZE];
//以只读的方式打开from指向的文件
//open()当打开文件成功时,返回一个文件描述符;当打开失败时,返回-1,并且errno为错误码
if((fromfd = open(from,O_RDONLY)) == -1)
{
//将出错原因打印出来
perror("open");
//返回
exit(1);
}
//以只写方式打开文件描述符为to的文件
//O_CREAT:如果to指向的文件不存在就创建该文件
//O_TRUNC:如果to指向的文件是已经存在的普通文件,并且打开的方式是可写的,就将该文件的长度截为0。对于FIFO文件或者终端设备文件,该方式被忽略
//如果文件存在,则以只读方式打开,并将文件清空;否则创建该文件
if((tofd = open(to,O_WRONLY | O_CREAT | O_TRUNC,S_IRUSR | S_IWUSR )) == -1)
{
//将出错原因打印出来
perror("open to");
//返回
exit(1);
}
//将文件描述符为fromfd的文件中读取长度为buf的字节的数据并放入buf缓冲区中
//read():执行成功时,返回的是实际读回数据的字节数;当失败时,返回-1,并且errno为错误码
nread = read(fromfd,buf,sizeof(buf));
//当nread>0,也就是还有数据没读完的时候,继续循环
while(nread > 0)
{
//将buf缓冲区中的nread个字节的数据写入文件描述符为tofd的文件中
//write():执行成功时,返回的是实际写入数据的字节数;当失败时,返回-1,并且errno为错误码
//当写入的数据和要写入的数据不符的时候
if(write(tofd,buf,nread)!=nread)
{
//提示写入出错
printf("write %s error\n",to);
}
//重新赋值nread,以便继续循环
nread = read(fromfd,buf,sizeof(buf));
}
//如果nread==-1,说明read执行失败
if(nread == -1){
//提示写入出错
printf("write %s error\n",to);
}
//关闭文件描述符为fromfd的文件
close(fromfd);
//关闭文件描述符为tofd的文件
close(tofd);
//返回
return;
}
//主函数定义
main(int argc,char **argv)
{
//如果传入的参数不等于3时(argc不等于3)
if(argc!=3)
{
//给出程序执行时的提示
printf("Usage:%s fromfilename tofilename\n",argv[0]);
//返回
exit(1);
}
//调用copy()函数,将传入的第一个参数对应的文件复制为第二个参数的文件
copy(argv[1],argv[2]);
}