命题:将一个文件中的内容复制到另一个文件中进行保存
首先分析命题可以知道,复制的操作,使用到的是Linux中的read,write,lseek等操作,因此本文章着重使用这三个函数进行文件的复制
作者在这里顺便使用了Makefile,shell脚本来帮助快速编译,为了让读者看到更加清晰的Makefile含义,本文使用最笨的方法来进行编写。
从上面可以看到作者设置了5个文件,其中test.c为复制的程序,被复制的文件为uart_test.c,复制保存的文件为:out.c,test.o和test是执行shell脚本时候生成的文件。
1.创建Makefile文件,Ubuntu中的命令:vim Makefile
2.撰写shell的脚本文件
3.撰写test.c进行具体的复制操作
#include <stdio.h>
#include <unistd.h>
#include <sys/types.h>
#include <sys/stat.h>
#include <fcntl.h>
#include <string.h>
#define BUFFSIZE 512
#define ERRORMSG() {printf("Line %d:operation failed\n",__LINE__);}
#define SUCCESSMSG() {printf("operation successfully\n");}
int main(int argc,char *argv[])
{
int inFd = -1;
char fileBuf[BUFFSIZE];
memset(fileBuf,0,sizeof(fileBuf));
inFd = open("./uart_test.c",O_RDONLY);
if(-1 == inFd)
{
ERRORMSG();
return -1;
}
SUCCESSMSG();
int outFd = -1;
outFd = open("./out.c",O_CREAT|O_TRUNC|O_WRONLY,0777);
if(-1 == outFd)
{
ERRORMSG();
return -1;
}
SUCCESSMSG();
int retData = 0;
while(retData = read(inFd,fileBuf,BUFFSIZE-1))
{
static int ret = 0;
ret += retData;
lseek(inFd,SEEK_SET,ret);
printf("%s",fileBuf);
write(outFd,fileBuf,strlen(fileBuf));
memset(fileBuf,0,BUFFSIZE);
}
close(outFd);
close(inFd);
return 0;
}
分析上面的程序中需要注意的是,在read的时候,为了保证读取的数据都是完整的,必须保证在数组缓冲区中不会造成越界的情况,因此读取的内容是数组(长度-1)的长度,这时候数组会自动在数组尾部自动添加结束符号'\0',保证内存不溢;另一个原因是,如果不做上述的处理,编译器可能不会发出警告,但是读取到的内容在数组空间的末尾位置产生乱码,这是因为结束码影响的,同时即使设置了如:fileBuf[strlen(fileBuf)-1] = '\0',这样的话,虽然可以保证安全,但是必然丢失数据。
lseek是用来设置指针的偏移量的,读取数据的指针必须跟着已经读取的内容进行变化,否则容易造成重复复制动作
write用来把数据写进一个文档中
4.最后使用diff来检测是否完整复制(如果复制完整,不会提示什么,否则,将会输出不同的信息)
以上便是一个简单的复制文件的操作