IO进程---day2

1、使用fread和fwrite完成两个文件的拷贝,要求源文件和目标文件由外界输入

cpp 复制代码
#include<myhead.h>
int main(int argc, const char *argv[])
{
    //判断传入的文件个数是否为3
    if(argc != 3)
    {
        fprintf(stderr, "input file error\n");
        fputs("usage:./a.out srcfile destfile\n", stderr);
        return -1;
    }

    //以读写的形式打开源文件
    FILE *srcfp = fopen(argv[1], "r+");
    if(srcfp ==NULL)
    {    
        perror("srcfile open error");
        return -1;
    }
 //以写的形式打开目标文件
    FILE *destfp = fopen(argv[2], "w");
    if(destfp == NULL)
    {
        perror("destfile open error");
        return -1;
    }

    //定义一个中间字符数组
    char arr[10] = "";
	//int res;

        //从源文件中读取数据放入字符数组中
	 while(1)
	 {
		 int res = fread(arr, 1, 1, srcfp);
		//res为0,读取结束
		if( res<1 )
		{
			break;
		}
		 //将读取的字符串写入到新文件中
      	fwrite(arr,1,1,destfp);
	 }

    //关闭文件
    fclose(srcfp);
    fclose(destfp);
    return 0;
}

2、 使用fgets获取当前文件的总行数,并向文件中每一秒打印当前系统时间

3、思维导图

相关推荐
xiaozhiwise23 分钟前
Makefile 之 自动化变量
linux
意疏3 小时前
【Linux 篇】Docker 的容器之海与镜像之岛:于 Linux 系统内探索容器化的奇妙航行
linux·docker
BLEACH-heiqiyihu3 小时前
RedHat7—Linux中kickstart自动安装脚本制作
linux·运维·服务器
一只爱撸猫的程序猿3 小时前
一个简单的Linux 服务器性能优化案例
linux·mysql·nginx
我的K84094 小时前
Flink整合Hudi及使用
linux·服务器·flink
1900434 小时前
linux6:常见命令介绍
linux·运维·服务器
Camellia-Echo4 小时前
【Linux从青铜到王者】Linux进程间通信(一)——待完善
linux·运维·服务器
Linux运维日记5 小时前
k8s1.31版本最新版本集群使用容器镜像仓库Harbor
linux·docker·云原生·容器·kubernetes
我是唐青枫5 小时前
Linux dnf 包管理工具使用教程
linux·运维·服务器