本次实验主要是实现在同一目录下复制一个文件。
实验环境为阿里云ubuntu16.04编译器是gcc 5.4版本。
#include <stdio.h>
#include <unistd.h>
#include <sys/types.h>
#include <sys/stat.h>
#include <fcntl.h>
#include <stdlib.h>
#include <errno.h>
#include <string.h>
#define ERR_EXIT(m) \
do \
{ \
perror(m); \
exit(EXIT_FAILURE); \
}while(0)
int main(int argc,char *argv[])
{
int infd,outfd;
if(argc != 3)
{
fprintf(stderr,"usage %s src dest\n",argv[0]);
}
infd = open(argv[1],O_RDONLY);
if(infd == -1)
{
ERR_EXIT("open error");
}
if((outfd = open(argv[2],O_WRONLY | O_CREAT | O_TRUNC,0644)) == -1)
{
ERR_EXIT("open dest error");
}
char buf[1024];
int nread;
while((nread = read(infd,buf,1024)) > 0)
{
write(outfd,buf,nread);
}
close(infd);
close(outfd);
return 0;
}
这是我第一次用主函数中的参数,第一个参数为 int argc,第二个参数为char *argv[]。
main()括号内是固定的写法。argv是一个指针数组,他的元素个数是argc,存放的是指向每一个参数的指针,他的第一个元素即argv[0]为编译生成的可执行文件名(包括路径eg:"F:\VC\Ex1\Debug\Ex1.exe"),从二个元素(argv[1])开始,是每一个参数 .
int argc 表示argv的大小,是实际参数个数+1,其中+1是因为argv[0]是编译后的可执行文件名。(网上找的解释大致就是这个意思)
这是执行方法,01cp.cpp是被复制的文件,02cp.cpp是复制的文件,意思是02cp.cpp是复制01cp.cpp 的内容。
执行的结果验证确实是复制的结果,和预想的一样。
while((nread = read(infd,buf,1024)) > 0)
{
write(outfd,buf,nread);
}
这句代码怎么理解。
read 读infd文件描述符的内容,存在buf缓存中。nread接收的是读到字符数。然后写到outfd文件描述符对应的文件中。到循环在此读infd文件描述符的时候。nread为0.因为01cp.cpp没有1024个字符,假如01cp.cpp中大于1024个字符,那么会在读1024之后的字符写入outfd文件中,直到复制完。