【C 语言】文件操作 ( 使用 fread 和 fwrite 实现二进制文件的拷贝 | stat 统计文件大小 | feof 判定文件结尾 )

简介: 【C 语言】文件操作 ( 使用 fread 和 fwrite 实现二进制文件的拷贝 | stat 统计文件大小 | feof 判定文件结尾 )

文章目录

一、stat 统计文件大小

二、feof 判定文件结尾

三、使用 fread 和 fwrite 实现二进制文件的拷贝





一、stat 统计文件大小


统计文件大小 , 需要借助 stat 结构体 , 调用 stat 方法 , 将该结构体的指针作为参数传入 , 文件的大小会写出到 stat 结构体的 _off_t st_size 成员中 ;


=  struct stat {
    _dev_t st_dev;
    _ino_t st_ino;
    unsigned short st_mode;
    short st_nlink;
    short st_uid;
    short st_gid;
    _dev_t st_rdev;
    _off_t st_size;
    time_t st_atime;
    time_t st_mtime;
    time_t st_ctime;
  };


调用 stat 方法 , 传入文件路径 , 以及 struct stat 结构体变量 , 即可统计文件的大小 , 最终将文件信息保存到结构体中 ;


stat 方法原型 :


int __cdecl stat(const char *_Filename,struct stat *_Stat);


代码示例 :


 

// 判断文件大小 , 该结构体接收文件大小结果
    struct stat st = {0};
    // 判断 src.avi 文件的大小
    stat("D:/File/src.avi", &st);
    // 计算缓冲区文件大小
    int buffer_size = st.st_size;





二、feof 判定文件结尾


进行文件操作时 , 使用 feof 方法判定是否读取到了文件结尾 ;


参考 【C 语言】文件操作 ( 文件结尾判定 ) 博客 ;



代码示例 :


 

// 判定文件指针是否指向文件末尾
    // 如果指向末尾 , 说明该文件
    while (!feof(p_src)) {
    }





三、使用 fread 和 fwrite 实现二进制文件的拷贝


代码示例 :


#include <stdio.h>
#include <stdlib.h>
#include <sys/stat.h>
/* 定义最大缓冲区大小 ,
 * 如果文件小于 64 KB , 则缓冲区就是文件大小 ,
 * 如果文件大于 64 KB , 则缓冲区就是该大小
 */
#define BUFFER_SIZE 1024 * 64
int main()
{
    printf("Start Copy\n");
    // 拷贝的源地址
    char *src_file = "D:/File/src.avi";
    // 拷贝的目标地址
    char *dst_file = "D:/File/dst.avi";
    // 以 可读 + 二进制 方式打开文件
    // r 表示可读打开方式
    // 打开方式后添加 b , 表示以二进制形式打开
    FILE *p_src = fopen(src_file, "rb");
    // 如果打开失败 , 直接返回
    if(p_src == NULL){
        printf("src_file open failed");
        return 0;
    }
    // 以 可写 + 二进制 方式打开文件
    // w 表示可写打开方式
    // 打开方式后添加 b , 表示以二进制形式打开
    FILE *p_dst = fopen(dst_file, "wb");
    // 如果打开失败 , 直接返回
    if(p_dst == NULL){
         printf("dst_file open failed");
        return 0;
    }
    // 判断文件大小 , 该结构体接收文件大小结果
    struct stat st = {0};
    // 判断 src.avi 文件的大小
    stat("D:/File/src.avi", &st);
    // 计算缓冲区文件大小
    // 如果文件小于 64KB , 则缓冲区大小就是文件大小
    // 如果文件大于 64KB , 则缓冲区大小就是 64KB
    int buffer_size = st.st_size;
    if(buffer_size > BUFFER_SIZE)
        buffer_size = BUFFER_SIZE;
    // 为缓冲区内存申请堆内存
    char *buffer = malloc(buffer_size);
    // 判定文件指针是否指向文件末尾
    // 如果指向末尾 , 说明该文件
    while (!feof(p_src)) {
        // 读取源文件数据到 buffer 缓冲区, 读取 buffer_size 个字节
        // 如果没有那么多字节 , 将读取的字节数返回
        int res = fread(buffer, 1, buffer_size, p_src);
        // 将读取到缓冲区中的数据写出到目标文件中
        fwrite(buffer, 1, res, p_dst);
    }
    // 释放缓冲区内存
    free(buffer);
    // 关闭源文件
    fclose(p_src);
    // 关闭目标文件
    fclose(p_dst);
    printf("Copy Success");
    return 0;
}



拷贝结果展示 :


image.png

目录
相关文章
|
11天前
|
存储 C语言
【c语言】玩转文件操作
本文介绍了C语言中文件操作的基础知识,包括文件的打开和关闭、文件的顺序读写、文件的随机读写以及文件读取结束的判定。详细讲解了`fopen`、`fclose`、`fseek`、`ftell`、`rewind`等函数的使用方法,并通过示例代码展示了如何进行文件的读写操作。最后,还介绍了如何判断文件读取结束的原因,帮助读者更好地理解和应用文件操作技术。
19 2
|
16天前
|
存储 编译器 C语言
如何在 C 语言中判断文件缓冲区是否需要刷新?
在C语言中,可以通过检查文件流的内部状态或使用`fflush`函数尝试刷新缓冲区来判断文件缓冲区是否需要刷新。通常,当缓冲区满、遇到换行符或显式调用`fflush`时,缓冲区会自动刷新。
|
16天前
|
存储 编译器 C语言
C语言:文件缓冲区刷新方式有几种
C语言中文件缓冲区的刷新方式主要包括三种:自动刷新(如遇到换行符或缓冲区满)、显式调用 fflush() 函数强制刷新、以及关闭文件时自动刷新。这些方法确保数据及时写入文件。
|
22天前
|
存储 C语言
简述C语言文件操作
简述C语言文件操作
9 0
|
27天前
|
存储 文件存储 C语言
深入C语言:文件操作实现局外影响程序
深入C语言:文件操作实现局外影响程序
|
26天前
|
C语言 C++
C语言 之 内存函数
C语言 之 内存函数
31 3
|
17天前
|
存储 缓存 C语言
【c语言】简单的算术操作符、输入输出函数
本文介绍了C语言中的算术操作符、赋值操作符、单目操作符以及输入输出函数 `printf` 和 `scanf` 的基本用法。算术操作符包括加、减、乘、除和求余,其中除法和求余运算有特殊规则。赋值操作符用于给变量赋值,并支持复合赋值。单目操作符包括自增自减、正负号和强制类型转换。输入输出函数 `printf` 和 `scanf` 用于格式化输入和输出,支持多种占位符和格式控制。通过示例代码详细解释了这些操作符和函数的使用方法。
31 10
|
10天前
|
存储 算法 程序员
C语言:库函数
C语言的库函数是预定义的函数,用于执行常见的编程任务,如输入输出、字符串处理、数学运算等。使用库函数可以简化编程工作,提高开发效率。C标准库提供了丰富的函数,满足各种需求。
|
16天前
|
机器学习/深度学习 C语言
【c语言】一篇文章搞懂函数递归
本文详细介绍了函数递归的概念、思想及其限制条件,并通过求阶乘、打印整数每一位和求斐波那契数等实例,展示了递归的应用。递归的核心在于将大问题分解为小问题,但需注意递归可能导致效率低下和栈溢出的问题。文章最后总结了递归的优缺点,提醒读者在实际编程中合理使用递归。
40 7
|
16天前
|
存储 编译器 程序员
【c语言】函数
本文介绍了C语言中函数的基本概念,包括库函数和自定义函数的定义、使用及示例。库函数如`printf`和`scanf`,通过包含相应的头文件即可使用。自定义函数需指定返回类型、函数名、形式参数等。文中还探讨了函数的调用、形参与实参的区别、return语句的用法、函数嵌套调用、链式访问以及static关键字对变量和函数的影响,强调了static如何改变变量的生命周期和作用域,以及函数的可见性。
25 4