底层文件操作的各种函数(二)------printf,fprintf,sprintf,scanf,fscanf,sscanf的对比以及文件缓冲区

简介: 底层文件操作的各种函数(二)------printf,fprintf,sprintf,scanf,fscanf,sscanf的对比以及文件缓冲区

偷得几日清闲,又因一瞬之间对蹉跎时间的愧疚,由此而来到CSDN这个高手云集和新手求学的平台来也写上那么一篇博客。虽然自己的博客那么久不温不热,但坚持写作,巩固自己就好。今天要讲的是续接上一篇文章的补充与继续吧。


常常会回顾努力的自己,所以要给自己的努力留下足迹。

为今天努力的自己打个卡,留个痕迹吧


fprintf与fscanf

fpritf

将格式化数据写入流式处理


将按格式指向的 C 字符串写入流。如果 format 包含格式说明符(以 % 开头的子序列),则格式后面的其他参数将被格式化并插入到生成的字符串中,以替换其各自的说明符。

格式:

int fprintf ( FILE * stream, const char * format, ... );


此函数所要包含的头文件如上图也是stdio.h。此函数与printf非常相似,只是多了个流的选择,也就是我们可以选择把要打印的东西打印到一个文件中。如下代码:

#define _CRT_SECURE_NO_WARNINGS 1
#include<stdio.h>
int main()
{
  int age = 18;
  char a[] = "Sam";
  double high = 188.8;
  FILE* pf = fopen("test0409.txt", "w");
  if (pf == NULL)
  {
    perror("fopen");
  }
 
  fprintf(pf, "名字:%s 年龄:%d 身高:%f", a, age, high);
  fclose(pf);
  pf = NULL;
 
 
  return 0;
}


我们一经运行,就可以打开文件目录,查看我们要打印的东西是否打印到我们的文本文件

如上我们已经完成了打印。


fscanf

中读取数据,并根据参数格式将它们存储到其他参数所指向的位置。

其他参数应指向已分配的对象,该对象的类型由格式字符串中的相应格式说明符指定。

这里我们把上面创建的test0409的文件改一下,便于fscanf读取,改后的文本如下 :

int main()
{
  int age ;
  char a[10] ;
  float high ;
  FILE* pf = fopen("test0409.txt", "r");//现在以只读的方式打开文件
  if (pf == NULL)
  {
    perror("fopen");
  }
 
  fscanf( pf,"%s %d %f", a,&age,&high);
  //看看是否完成读取了,打印出来。
  printf("名字:%s 年龄:%d 身高:%f", a, age, high);
  fclose(pf);
  pf = NULL;
 
 
  return 0;
}

如上面代码,我们现以”r“的方式打开文件,然后再让fscanf读取文本中对应占位符所对应的数据,并放到相应的变量中,最后再把这些变量打印再屏幕上

这里身高是不完全标准的,不是188.800000,而是 188.800003,为什么呢,这是因为这与浮点数的储存是有关系的,浮点数对有些数字是无法做到精确的储存的

sprintf与sscanf

sprintf

将格式化数据写入字符串


使用与在 printf 上使用格式时打印的文本相同的文本组成一个字符串,但内容不是被打印,而是作为 C 字符串存储在 str 指向的缓冲区中。


缓冲区的大小应足够大,以包含整个生成的字符串


终止 null 字符会自动追加在内容之后。


在 format 参数之后,该函数至少需要与格式所需的附加参数一样多的参数。


简单点来说就是:将数据打印的地方从屏幕到一个指针(数组里)。

格式:

int sprintf ( char * str, const char * format, ... );

给大家举一个简单的代码例子:

这里我们现创建一个数组(足够能储存等下你要打印的数据),然后创建打印数据,然后其它正常像printf一样打印,只需前面多一个数组名(指针)。

int main()
{
  char a[100];
  int i = 18;
  int j = 180;
  char* q = "hello world";
  
 
    sprintf(a, "年龄:%d 起点:%s 理想身高:%d",i ,q ,j);
    printf("%s", a);
 
  return 0;
}

如上我们打印数组a也是可以把刚刚fprintf的数据打印出来了,说明我们刚刚确实用fprintf打印到数组a中了。


sscanf 

从字符串中读取格式化数据

从 s 读取数据,并根据参数格式将它们存储到附加参数给定的位置,就像使用 scanf 一样,但从 s 读取而不是标准输入 (stdin)。

其他参数应指向已分配的对象,该对象的类型由格式字符串中的相应格式说明符指定。

int sscanf ( const char * s, const char * format, ...);


这里也是简单示例一下:

我们这里从一个数组中读取数据放到另一个数组当中。

int main()
{
  char a[100] = {"helloworld"};
    char arr[100];
    sscanf(a, "%s",arr );
    printf("%s", arr);
 
  return 0;
}


printf,fprintf,sprintf,scanf,fscanf,sscanf的对比

首先最简单的scanf和printf


所用的流规定默认是标准输出流(stdout)和标准输入流(stdin),换句话来说就是:将数据输出到我们的屏幕上或从我们的屏幕读取数据。


fprintf和fscanf


所用的流可以是任何流,既可以是文件也可以是 标准输出流(stdout)和标准输入流(stdin),这里所用的流没有规定我们可以自由选择,需要作为参数传给函数,经过这么一解释,大家是否想说如果我们把 标准输出流(stdout)传给sprintf,把标准输入流(stdin)传给sscanf,是不是就是我们常用的printf和scanf了呢,答案确实是如此,所以你可以理解fprintf和fscanf只是多了选择流的权力。

这里给大家演示一下吧。

int main()
{
  int i = 0;
  printf("输入一个整数");
  fscanf(stdin, "%d", &i);
 
  fprintf(stdout,"%d", i);
  return 0;
}


这里也是从屏幕上输入,再屏幕输出,OK,这两个函数就是这样了。


sprintf与sscanf

这两个函数就是将数据传入数组或从一个数组中读取数据,简单来说就是他们操作的对象是数组而不是流。

文件缓冲区

文件缓冲区,我们可以把他想象为一个水桶,而我们拿这个水桶来接水,而我们接水需要到一定的水量我们才拿走的不然一次拿一点水不够用,需要一次一次来打水太浪费时间,除非有人强制我们拿走这桶水。而我们的缓冲区便是如此。


可能大家会说,可是我们之前写的数据也是一点点,但还是把数据写入文件了,并没有像你所说要等缓冲区满了才会放入文件中,其实上面也说到一个“除非”,那就是被去强制写入硬盘文件里了,那什么操作会强制呢,其中之一那便是fclose,也就是关闭文件的操作会将缓冲区的数据输出到硬盘。还有一个fflush函数,也可以刷新缓冲区,也就是强制将数据输出或输入。


常常会回顾努力的自己,所以要给自己的努力留下足迹。

为今天努力的自己打个卡,留个痕迹吧

目录
相关文章
|
27天前
|
弹性计算 人工智能 架构师
阿里云携手Altair共拓云上工业仿真新机遇
2024年9月12日,「2024 Altair 技术大会杭州站」成功召开,阿里云弹性计算产品运营与生态负责人何川,与Altair中国技术总监赵阳在会上联合发布了最新的“云上CAE一体机”。
阿里云携手Altair共拓云上工业仿真新机遇
|
3天前
|
人工智能 Rust Java
10月更文挑战赛火热启动,坚持热爱坚持创作!
开发者社区10月更文挑战,寻找热爱技术内容创作的你,欢迎来创作!
370 16
|
19天前
|
存储 关系型数据库 分布式数据库
GraphRAG:基于PolarDB+通义千问+LangChain的知识图谱+大模型最佳实践
本文介绍了如何使用PolarDB、通义千问和LangChain搭建GraphRAG系统,结合知识图谱和向量检索提升问答质量。通过实例展示了单独使用向量检索和图检索的局限性,并通过图+向量联合搜索增强了问答准确性。PolarDB支持AGE图引擎和pgvector插件,实现图数据和向量数据的统一存储与检索,提升了RAG系统的性能和效果。
|
6天前
|
JSON 自然语言处理 数据管理
阿里云百炼产品月刊【2024年9月】
阿里云百炼产品月刊【2024年9月】,涵盖本月产品和功能发布、活动,应用实践等内容,帮助您快速了解阿里云百炼产品的最新动态。
阿里云百炼产品月刊【2024年9月】
|
21天前
|
人工智能 IDE 程序员
期盼已久!通义灵码 AI 程序员开启邀测,全流程开发仅用几分钟
在云栖大会上,阿里云云原生应用平台负责人丁宇宣布,「通义灵码」完成全面升级,并正式发布 AI 程序员。
|
23天前
|
机器学习/深度学习 算法 大数据
【BetterBench博士】2024 “华为杯”第二十一届中国研究生数学建模竞赛 选题分析
2024“华为杯”数学建模竞赛,对ABCDEF每个题进行详细的分析,涵盖风电场功率优化、WLAN网络吞吐量、磁性元件损耗建模、地理环境问题、高速公路应急车道启用和X射线脉冲星建模等多领域问题,解析了问题类型、专业和技能的需要。
2592 22
【BetterBench博士】2024 “华为杯”第二十一届中国研究生数学建模竞赛 选题分析
|
5天前
|
存储 人工智能 搜索推荐
数据治理,是时候打破刻板印象了
瓴羊智能数据建设与治理产品Datapin全面升级,可演进扩展的数据架构体系为企业数据治理预留发展空间,推出敏捷版用以解决企业数据量不大但需构建数据的场景问题,基于大模型打造的DataAgent更是为企业用好数据资产提供了便利。
181 2
|
3天前
|
编译器 C#
C#多态概述:通过继承实现的不同对象调用相同的方法,表现出不同的行为
C#多态概述:通过继承实现的不同对象调用相同的方法,表现出不同的行为
105 65
|
7天前
|
Linux 虚拟化 开发者
一键将CentOs的yum源更换为国内阿里yum源
一键将CentOs的yum源更换为国内阿里yum源
332 2
|
23天前
|
机器学习/深度学习 算法 数据可视化
【BetterBench博士】2024年中国研究生数学建模竞赛 C题:数据驱动下磁性元件的磁芯损耗建模 问题分析、数学模型、python 代码
2024年中国研究生数学建模竞赛C题聚焦磁性元件磁芯损耗建模。题目背景介绍了电能变换技术的发展与应用,强调磁性元件在功率变换器中的重要性。磁芯损耗受多种因素影响,现有模型难以精确预测。题目要求通过数据分析建立高精度磁芯损耗模型。具体任务包括励磁波形分类、修正斯坦麦茨方程、分析影响因素、构建预测模型及优化设计条件。涉及数据预处理、特征提取、机器学习及优化算法等技术。适合电气、材料、计算机等多个专业学生参与。
1580 17
【BetterBench博士】2024年中国研究生数学建模竞赛 C题:数据驱动下磁性元件的磁芯损耗建模 问题分析、数学模型、python 代码