八种顺序读写函数的介绍(fput/getc;fput/gets;fscanf,fprintf;fwrite,fread)

本文主要是介绍八种顺序读写函数的介绍(fput/getc;fput/gets;fscanf,fprintf;fwrite,fread),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一:读写的含义的解释:

读(读出):即从文件里面读出数据----------->和scanf从键盘里面读出数据类似

写(写入):即把数据写入文件里面----------->和printf把数据写入到屏幕上类似


二:使用读写函数的模型:

1,打开文件

 函数功能:用于打开一个文件,并返回一个与该文件关联的FILE指针。

参数解释:

  • filename:这是您想要打开的文件的名称(包括路径,如果文件不在当前目录下)。
  • mode:这是一个字符串,用于指定文件应如何被打开。例如,"r"表示只读模式,"w"表示写模式(如果文件不存在,则创建它;如果文件存在,则覆盖它),"a"表示追加模式(如果文件不存在,则创建它;如果文件存在,则在文件末尾追加内容),等等。

2,通过打开文件的返回值判断是否打开成功

3,进行读写操作
4,关闭文件,置空文件指针

函数功能:用于关闭一个已打开的文件。

参数解释:stream是需要被关闭的文件的文件指针

?:那为什么scanf printf的时候,直接使用就行了,不需要打开什么??

这是因为c语言程序,只要运行起来,就会默认打开3个流
1,标准输入流 stdin 
2,标准输出流 stdout 
3,标准错误流 stderr 

三个流的类型依然是 FILE*,和读写函数的参数一致

三:读写函数的参数特点:
都是与 FILE * stream(流)有关,流是什么? 流可以是文件,从流里面读出数据,写入数据到流里面,只是不同的读写函数去读写的数据不一样,一些是把单个字符写入到流,或从流里读出单个字符,一些是字符串的读写,一些是二进制的读写
四:顺序读写函数的介绍
1:fputc函数

 函数功能:

        将字符写入到文件中,写入一个字符后,文件的“当前位置”就会向前移动一个字符的位置。(将 int character 写入到 FILE * stream 中)

返回值:

  • 函数返回一个int类型的值。如果写入成功,它返回写入的字符。如果发生错误,它返回EOF(End Of File,文件结束标志)。

函数的使用展示:

第一种( 用fputc函数,将一个字符a写入到文件中,该文件名为data.txt)

第二种(用fputc函数,将英文字母表写入到文件中,该文件名为data.txt) 

2:fgetc函数

 函数功能: 

        从指定的文件流(stream)中读取一个字符

返回值:

        返回该字符的 ASCII 值。如果文件流已经到达文件末尾,则返回 EOF(End Of File,一个特殊的常量,通常在大多数系统中定义为 -1)。

函数的使用展示:

第一种( 用fgetc函数,从文件中获取一个字符,该文件名为data.txt)

data.txt文件统一为我们在vs路径下创建的一个英文字母表文本文件

 第二种( 用fgetc函数,从文件中获取字母表的全部字符,该文件名为data.txt)

3:fputs函数

函数功能:

        将字符串写入到指定的文件流中(将字符串str写入到文件流stream中)

 返回值:

  • 函数返回一个整数。如果成功,它将返回非负值(通常是EOF之外的任何值)。如果发生错误(例如,流是无效的或不可写的),则返回EOF

函数使用展示:

可知:该函数不会换行,需要自己加\n

4:fgets函数 

函数功能:

        从指定的文件流中读取一个字符串(从文件流stream中读取一个最大字符数为(num-1)的字符串str) 

注意:

  • fgets 从 stream 中读取字符,并将它们存储为 C 字符串到 str 中,直到读取了 (num-1) 个字符或遇到换行符(\n)或文件结束符(EOF)为止,以先到者为准。
  • 如果遇到换行符,fgets 会停止读取,但该换行符仍然被认为是有效的字符,并被包含在复制到 str 的字符串中。
  • 在复制到 str 的字符之后,fgets 会自动附加一个终止的空字符(\0),以确保 str 是一个有效的 C 字符串。

返回值:读取成功返回 str,读取失败返回NULL

函数使用展示

第一种:从data.txt中读取num为10,也就是num-1,9个字符,作为一个字符串str(注意中的第一点

第二种:从data.txt中读取远远超过文件本身的字符长度,作为一个字符串str(注意中的第二点

!:虽然100远远超过文件里的字符串长度,但是遇到 \n 就会自己停止读取

5:fprintf函数

函数功能:

        将格式化的数据写入到指定的文件流中

参数解释:

  1. const char *format:这是一个格式字符串,指定了如何格式化后面的参数。格式字符串可以包含普通字符和格式说明符(以 % 开头的子序列)。普通字符会被原样复制到输出流中,而格式说明符会被后面传入的参数替换。
  2. ...:这是一个可变参数列表,表示 fprintf 函数可以接受任意数量的额外参数。这些参数的数量和类型应该与格式字符串中的格式说明符相匹配。

返回值:

  1. On success, the total number of characters written is returned.

    • 当操作成功时,返回写入的字符总数。
    • 这意味着,如果你写入了5个字符,并且没有发生任何错误,那么该函数将返回5。
  2. If a writing error occurs, the error indicator (ferror) is set and a negative number is returned.

    • 如果在写入过程中发生错误,那么错误指示器(通常是一个变量或标志)将被设置,并且返回一个负数。
    • 这种返回值可以帮助调用者(即使用该函数的代码)知道发生了错误,并且可以通过检查ferror来确定错误的具体原因。

函数使用展示

将一个整数和一个浮点数写入到文件中

6:fscanf 函数 

函数功能:

        从文件中读取格式化的数据

参数解释:

  1. **const char *format**:

    • 这是一个格式字符串,它指定了应该如何读取和解析数据。格式字符串中的格式说明符(如 %d%s%f 等)告诉 fscanf 应该如何解释和存储数据。
  2. **...**:

    • 这表示函数接受可变数量的参数,这些参数是根据格式字符串中的格式说明符来指定的。

返回值:

  1. 成功时的返回

    • 当函数成功执行时,它会返回成功填充到参数列表中的项目数量。
    • 这个数量可能与预期的项目数量相同,但也可能更少(甚至为零)。
  2. 为什么会比预期少

    • 匹配失败:可能是因为输入的数据与预期的格式或模式不匹配。
    • 读取错误:在尝试读取数据时,可能会发生某种错误,如文件损坏或磁盘错误。
    • 达到文件末尾:如果函数正在从文件中读取数据,并且已经到达了文件的末尾,那么它可能无法填充更多的项目。(一般这种原因居多)
  3. 关于错误指示

    • 如果在读取过程中发生读取错误或达到文件末尾,相应的标志(如feofferror)会被设置。
    • 如果在这些情况发生之前,函数还没有成功读取到任何数据,它会返回EOF(End Of File),这是一个特殊的值,表示文件结束或读取失败。

函数使用展示:

把我们创建好的文件data.txt中的整数和浮点数放回一个结构体中

 7:fwrite 函数 

函数功能: 

        将数据块以二进制的形式写入文件流(fwrite 从由 ptr 指向的内存块中取出 count 个元素,每个元素的大小为 size 字节,并将它们写入到 stream 指向的文件流中)

参数解释:

  1. ptr:指向要写入的数据块的指针。这个数据块可以是任何类型,不仅仅是字符。
  2. size:每个元素的大小(以字节为单位)。
  3. count:要写入的数据元素的数量。
  4. stream:指向要写入的文件流的指针。

返回值:

  1. The total number of elements successfully written is returned.

    • 这意味着该函数返回成功写入的元素总数。
  2. If this number differs from the count parameter, a writing error prevented the function from completing.

    • 如果返回的数量与传入的 count 参数不同,那么说明在写入过程中出现了错误,导致函数没有完成预期的写入操作。
  3. In this case, the error indicator (ferror) will be set for the stream.

    • 在出现写入错误的情况下,流的错误指示器(ferror)会被设置。这意味着您可以通过检查 ferror 来确定是否发生了写入错误。
  4. If either size or count is zero, the function returns zero and the error indicator remains unchanged.

    • 如果 size 或 count 参数中的任何一个为零,那么函数将返回零,并且流的错误指示器不会改变。这意味着在这种情况下,没有发生错误,但也没有写入任何数据。

函数使用展示:

从 s 中向 pf 中以二进制的形式写入 1 个大小为 sizeof(struct S) 的数据

 8:fread 函数 

函数功能:

        从文件流中读取数据(fread 函数从给定的文件流 stream 中读取数据。它读取 count 个元素,每个元素的大小为 size 字节,并将这些数据存储在由 ptr 指向的内存块中)

参数解释:

  1. void * ptr:这是一个指向要存储读取数据的内存块的指针。fread 会将读取的数据存储在这个内存块中。
  2. size_t size:每个要读取的元素的大小(以字节为单位)。
  3. size_t count:要读取的元素数量。
  4. FILE * stream:这是一个指向要从中读取数据的文件流的指针。

返回值:

  1. The total number of elements successfully read is returned.

    • 这意味着该函数返回成功读取的元素总数。
  2. If this number differs from the count parameter, either a reading error occurred or the end-of-file was reached while reading.

    • 如果返回的成功读取的元素总数与count参数不同,那么有两种可能的原因:
      1. 读取过程中发生了错误。
      2. 在读取过程中已经到达了文件的末尾。
  3. In both cases, the proper indicator is set, which can be checked with ferror and feof, respectively.

    • 在上述两种情况下,相应的指示器会被设置。你可以使用ferror函数来检查是否有读取错误,而使用feof函数来检查是否已到达文件末尾。
  4. If either size or count is zero, the function returns zero and both the stream state and the content pointed by ptr remain unchanged.

    • 如果sizecount中的任何一个为零,该函数会返回零,并且流的状态以及由ptr指向的内容都不会改变。

函数使用展示:

从 pf 中以二进制的形式读取 1 个大小为 sizeof(struct S) 的数据,放进 s 中

谢谢观看,祝你开心~

这篇关于八种顺序读写函数的介绍(fput/getc;fput/gets;fscanf,fprintf;fwrite,fread)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/857544

相关文章

Python容器转换与共有函数举例详解

《Python容器转换与共有函数举例详解》Python容器是Python编程语言中非常基础且重要的概念,它们提供了数据的存储和组织方式,下面:本文主要介绍Python容器转换与共有函数的相关资料,... 目录python容器转换与共有函数详解一、容器类型概览二、容器类型转换1. 基本容器转换2. 高级转换示

Java中ArrayList与顺序表示例详解

《Java中ArrayList与顺序表示例详解》顺序表是在计算机内存中以数组的形式保存的线性表,是指用一组地址连续的存储单元依次存储数据元素的线性结构,:本文主要介绍Java中ArrayList与... 目录前言一、Java集合框架核心接口与分类ArrayList二、顺序表数据结构中的顺序表三、常用代码手动

pandas使用apply函数给表格同时添加多列

《pandas使用apply函数给表格同时添加多列》本文介绍了利用Pandas的apply函数在DataFrame中同时添加多列,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习... 目录一、Pandas使用apply函数给表格同时添加多列二、应用示例一、Pandas使用apply函

在SpringBoot+MyBatis项目中实现MySQL读写分离的实战指南

《在SpringBoot+MyBatis项目中实现MySQL读写分离的实战指南》在SpringBoot和MyBatis项目中实现MySQL读写分离,主要有两种思路:一种是在应用层通过代码和配置手动控制... 目录如何选择实现方案核心实现:应用层手动分离实施中的关键问题与解决方案总结在Spring Boot和

Python中Namespace()函数详解

《Python中Namespace()函数详解》Namespace是argparse模块提供的一个类,用于创建命名空间对象,它允许通过点操作符访问数据,比字典更易读,在深度学习项目中常用于加载配置、命... 目录1. 为什么使用 Namespace?2. Namespace 的本质是什么?3. Namesp

MySQL中如何求平均值常见实例(AVG函数详解)

《MySQL中如何求平均值常见实例(AVG函数详解)》MySQLavg()是一个聚合函数,用于返回各种记录中表达式的平均值,:本文主要介绍MySQL中用AVG函数如何求平均值的相关资料,文中通过代... 目录前言一、基本语法二、示例讲解1. 计算全表平均分2. 计算某门课程的平均分(例如:Math)三、结合

MySQL数据库读写分离与负载均衡的实现逻辑

《MySQL数据库读写分离与负载均衡的实现逻辑》读写分离与负载均衡是数据库优化的关键策略,读写分离的核心是将数据库的读操作与写操作分离,本文给大家介绍MySQL数据库读写分离与负载均衡的实现方式,感兴... 目录读写分离与负载均衡的核心概念与目的读写分离的必要性与实现逻辑读写分离的实现方式及优缺点读负载均衡

Redis的安全机制详细介绍及配置方法

《Redis的安全机制详细介绍及配置方法》本文介绍Redis安全机制的配置方法,包括绑定IP地址、设置密码、保护模式、禁用危险命令、防火墙限制、TLS加密、客户端连接限制、最大内存使用和日志审计等,通... 目录1. 绑定 IP 地址2. 设置密码3. 保护模式4. 禁用危险命令5. 通过防火墙限制访问6.

Python函数作用域与闭包举例深度解析

《Python函数作用域与闭包举例深度解析》Python函数的作用域规则和闭包是编程中的关键概念,它们决定了变量的访问和生命周期,:本文主要介绍Python函数作用域与闭包的相关资料,文中通过代码... 目录1. 基础作用域访问示例1:访问全局变量示例2:访问外层函数变量2. 闭包基础示例3:简单闭包示例4

Python中isinstance()函数原理解释及详细用法示例

《Python中isinstance()函数原理解释及详细用法示例》isinstance()是Python内置的一个非常有用的函数,用于检查一个对象是否属于指定的类型或类型元组中的某一个类型,它是Py... 目录python中isinstance()函数原理解释及详细用法指南一、isinstance()函数