【C 语言】文件操作 ( 读取文件中的结构体数组 | feof 函数使用注意事项 )

简介: 【C 语言】文件操作 ( 读取文件中的结构体数组 | feof 函数使用注意事项 )

文章目录

一、读取文件中的结构体数组 | feof 函数使用注意事项

二、代码示例





一、读取文件中的结构体数组 | feof 函数使用注意事项


读取文件结构体时 , 可以循环读取文件中的数据 , 只使用一个结构体的内存空间即可 ;


使用 feof() 函数 判定当前是否读取到了文件结尾 , 如果读取到结尾 , 则退出不再读取数据 ;



feof 函数原型 :


#include<stdio.h>
int feof(FILE *stream);



feof() 函数判断文件结尾 , 是通过读取 读取 函数操作 的 错误值 确定的 , feof() 函数的调用必须 紧跟着 文件操作函数 进行判断 , 所有的其它逻辑 , 都放在 feof 判断之后 , 确定没有读取到文件末尾 , 再进行操作 , 如果读取返回了错误 , 则直接退出 ;


读取 文本文件 可以使用 getc , fgets , fscanf 函数 , 向 文本文件 写出数据可以使用 putc , fputs , fprintf 函数 ;


读取 二进制文件 可以使用 fread 函数 , 向 二进制文件 写出数据可以使用 fwrite 函数 ;



例如 : 在下面的代码示例中 , 读取文件后 , 马上判断是否读取到了文件末尾 , 至于读取到的数据操作 , 需要确定本次读取文件合法性后 , 没有读取到文件末尾 , 才能进行后续操作 ;



代码示例 :


 

// 存储读取到的结构体数据
    struct student s2= {0};
    while(1)
    {
        // 每次读取一个结构体,
        fread(&s2, 1, sizeof (struct student), p2);
        // 如果读取到文件末尾, 则退出循环
        if(feof(p2))
            break;
        // 打印读取到的结构体数据
        printf("%s, %d\n", s2.name, s2.age);
    }






二、代码示例


#include <stdio.h>
/* 定义结构体, 存储一个字符串和年龄 */
struct student
{
    char name[20];
    int age;
};
int main()
{
    // 要写入文件的结构体
    struct student s1[2] = {{"Tom", 18}, {"Jerry", 20}};
    // 打开要写入的文件
    FILE *p = fopen("D:/File/student.dat", "w");
    // 打开失败直接退出
    if(p == NULL)
        return 0;
    // 将结构体写出到文件中
    fwrite(s1, 2, sizeof (struct student), p);
    // 关闭文件
    fclose(p);
    // 读取文件中的结构体
    // 存储读取到的结构体数据
    struct student s2= {0};
    // 打开文件
    FILE *p2 = fopen("D:/File/student.dat", "r");
    // 如果打开失败, 退出
    if(p2 == NULL)
        return 0;
    while(1)
    {
        // 每次读取一个结构体,
        fread(&s2, 1, sizeof (struct student), p2);
        // 如果读取到文件末尾, 则退出循环
        if(feof(p2))
            break;
        // 打印读取到的结构体数据
        printf("%s, %d\n", s2.name, s2.age);
    }
    return 0;
}

image.png

目录
相关文章
|
5天前
|
存储 C语言
如何在 C 语言中实现结构体的深拷贝
在C语言中实现结构体的深拷贝,需要手动分配内存并逐个复制成员变量,确保新结构体与原结构体完全独立,避免浅拷贝导致的数据共享问题。具体方法包括使用 `malloc` 分配内存和 `memcpy` 或手动赋值。
22 10
|
2天前
|
存储 算法 程序员
C语言:库函数
C语言的库函数是预定义的函数,用于执行常见的编程任务,如输入输出、字符串处理、数学运算等。使用库函数可以简化编程工作,提高开发效率。C标准库提供了丰富的函数,满足各种需求。
|
8天前
|
机器学习/深度学习 C语言
【c语言】一篇文章搞懂函数递归
本文详细介绍了函数递归的概念、思想及其限制条件,并通过求阶乘、打印整数每一位和求斐波那契数等实例,展示了递归的应用。递归的核心在于将大问题分解为小问题,但需注意递归可能导致效率低下和栈溢出的问题。文章最后总结了递归的优缺点,提醒读者在实际编程中合理使用递归。
32 7
|
4天前
|
存储 大数据 编译器
C语言:结构体对齐规则
C语言中,结构体对齐规则是指编译器为了提高数据访问效率,会根据成员变量的类型对结构体中的成员进行内存对齐。通常遵循编译器默认的对齐方式或使用特定的对齐指令来优化结构体布局,以减少内存浪费并提升性能。
|
5天前
|
存储 C语言
【c语言】字符串函数和内存函数
本文介绍了C语言中常用的字符串函数和内存函数,包括`strlen`、`strcpy`、`strcat`、`strcmp`、`strstr`、`strncpy`、`strncat`、`strncmp`、`strtok`、`memcpy`、`memmove`和`memset`等函数的使用方法及模拟实现。文章详细讲解了每个函数的功能、参数、返回值,并提供了具体的代码示例,帮助读者更好地理解和掌握这些函数的应用。
9 0
|
5天前
|
C语言
【c语言】qsort函数及泛型冒泡排序的模拟实现
本文介绍了C语言中的`qsort`函数及其背后的回调函数概念。`qsort`函数用于对任意类型的数据进行排序,其核心在于通过函数指针调用用户自定义的比较函数。文章还详细讲解了如何实现一个泛型冒泡排序,包括比较函数、交换函数和排序函数的编写,并展示了完整的代码示例。最后,通过实际运行验证了排序的正确性,展示了泛型编程的优势。
8 0
|
5月前
|
C语言
C语言进阶——sprintf与sscanf、文件的随机读写(fseek、ftell、rewind)
C语言进阶——sprintf与sscanf、文件的随机读写(fseek、ftell、rewind)
41 0
|
存储 缓存 C语言
【C语言进阶】文件的顺序读写、随机读写、文本文件和二进制文件、文件读取结束的判定以及文件缓冲区相关知识(下)
【C语言进阶】文件的顺序读写、随机读写、文本文件和二进制文件、文件读取结束的判定以及文件缓冲区相关知识(下)
|
存储 C语言
【C语言进阶】文件的顺序读写、随机读写、文本文件和二进制文件、文件读取结束的判定以及文件缓冲区相关知识(中)
【C语言进阶】文件的顺序读写、随机读写、文本文件和二进制文件、文件读取结束的判定以及文件缓冲区相关知识(中)
|
编译器 数据库 C语言
【C语言进阶】文件的顺序读写、随机读写、文本文件和二进制文件、文件读取结束的判定以及文件缓冲区相关知识(上)
【C语言进阶】文件的顺序读写、随机读写、文本文件和二进制文件、文件读取结束的判定以及文件缓冲区相关知识(上)