Linux 实现cp 命令

cp 

用来复制文件或目录


下面说一下main函数的参数

int main(int ac , char **av)
也可写成

int main(int ac , char * av[])
第一个int型参数是命令行参数个数,第二个char ** 型参数是个字符指针数组,保存命令行各参数的名字(字符串)


比如对于cp来说 命令行有3个参数

cp file1 file2

则av[1] 存储 fille1这个字符串, av[2] 存储file2这个字符串, ac 等于3。

av[0] 不同环境有所不同:

经测Dev-C++ 中是D:\xx\xx\ cp01.exe

$ ./cp01 cp01.c copy_cp01.c
而我的Linux这样的命令行后av[0] 是 ./cp01

以上两者av[0]都是当前可执行文件名,前者包含了路径。


cp 用到了open函数来打开av[1];read函数读av[1];creat函数创建或清空av[2];write函数写入av[2];


/**
* cp01.c
* uses read and write with tunable buffer size
*/

#include<stdio.h>
#include<unistd.h>
#include<fcntl.h>

#define BUFF_SIZE 4096
#define COPY_MODE 0644

void oops(char * s1, char * s2);

int main(int ac, char **av)
{
	int  in_fd, out_fd, n_chars;
	char buf[BUFF_SIZE];
 
	/* check args */
	if( ac != 3)  // must three parameters
	{
		fprintf(stderr, "usage: %s source destination\n", *av);
	}

	/* open files */
	if( (in_fd = open(av[1], O_RDONLY)) == -1)
	{
		oops("Cannot open ", av[1]);
	}

	if( (out_fd = creat(av[2], COPY_MODE)) == -1 )
	{
		oops("Cannot creat ", av[2]);		
	}

	/* copy files */
	while( (n_chars = read(in_fd, buf, BUFF_SIZE)) > 0 )
	{
		if(write(out_fd, buf, n_chars) != n_chars )
		{
			oops("Write error from ", av[1]);
		}
	}

	if( n_chars == -1 )
	{
		oops("Read error from ", av[1]);
	}

	/* close files */
	if(close(in_fd) == -1 || close(out_fd) == -1)
	{
		oops("Error closing files", "");
	}

	return 0;
}

/**
* abnormal information
*/
void oops(char *s1, char *s2)
{
	fprintf(stderr, "Error: %s ", s1);
	perror(s2);
	exit(1);
}


用cmp比较复制的文件并无不同。

有趣的是

它可以复制它自己。



最后把cp01.c复制到Linux和Windows的共享文件夹。作用之一方便我把Linux里的代码粘贴到博客中来。



Linux中,可以使用文件IO的方式来实现cp命令的复制功能。具体步骤如下: 1. 打开源文件目标文件,可以使用open()函数,如下所示: ``` int src_fd = open("source_file", O_RDONLY); int dest_fd = open("destination_file", O_WRONLY|O_CREAT, S_IRUSR|S_IWUSR); ``` 其中,第一个参数为文件名,第二个参数为打开文件的模式,第三个参数为文件权限。 2. 读取源文件的内容并写入目标文件中,可以使用read()write()函数,如下所示: ``` char buffer[1024]; int read_size = 0; while((read_size = read(src_fd, buffer, sizeof(buffer))) > 0) { write(dest_fd, buffer, read_size); } ``` 其中,第一个参数为文件描述符,第二个参数为读取或写入的缓冲区,第三个参数为缓冲区的大小。 3. 关闭源文件目标文件,可以使用close()函数,如下所示: ``` close(src_fd); close(dest_fd); ``` 完整代码如下所示: ``` #include <stdio.h> #include <stdlib.h> #include <unistd.h> #include <fcntl.h> #include <sys/stat.h> int main(int argc, char *argv[]) { if(argc != 3) { printf("Usage: %s <source_file> <destination_file>\n", argv[0]); return 1; } int src_fd = open(argv[1], O_RDONLY); if(src_fd < 0) { printf("Failed to open source file: %s\n", argv[1]); return 1; } int dest_fd = open(argv[2], O_WRONLY|O_CREAT, S_IRUSR|S_IWUSR); if(dest_fd < 0) { printf("Failed to open destination file: %s\n", argv[2]); close(src_fd); return 1; } char buffer[1024]; int read_size = 0; while((read_size = read(src_fd, buffer, sizeof(buffer))) > 0) { write(dest_fd, buffer, read_size); } close(src_fd); close(dest_fd); return 0; } ``` 将上面的代码保存为cp.c文件,然后使用gcc编译即可生成可执行文件cp: ``` gcc cp.c -o cp ``` 使用方法: ``` ./cp source_file destination_file ``` 其中,source_file为源文件名,destination_file为目标文件名。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值