C++:cstdio 头文件详解

C++:cstdio 头文件详解<cstdio>(stdio.h)headerC库执行输入/输出操作:输入和输出操作也可以在C++实现,通过使用C标准输入和输出库(cstdio,在C语言中称为stdio.h)。这个库使用流来操作物理设备如键盘,打印机,终端或者系统支持的任何其他类型的文件。流是一种以统一的方式与这些交互的抽象; 所有流都具有相似的属性,与它们所关联的物理介质的各个特征无关。流…

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全家桶1年46,售后保障稳定

<cstdio> (stdio.h)

header


C库执行输入/输出操作:

输入和输出操作也可以在C++实现,通过使用C标准输入和输出库(cstdio,在C语言中称为stdio.h)。

这个库使用流来操作物理设备如键盘,打印机,终端或者系统支持的任何其他类型的文件。

流是一种以统一的方式与这些交互的抽象; 所有流都具有相似的属性,与它们所关联的物理介质的各个特征无关。

流在cstdio库中作为指向 FILE 的指针处理对象。一个指向FILE对象的指针唯一地标识一个流,并在涉及该流的操作中用作参数。

在使用库的时候会自动创建三个标准流:stdinstdout and stderr


流属性

Streams有一些属性可以定义可以在它们上使用哪些函数以及它们如何通过它们处理数据输入或输出。大多数这些属性是在流与使用 fopen 函数的文件(已打开)关联时定义的:

读/写访问 | 文字/二进制 | 缓冲 | 方向

指定流是否对与其关联的物理介质具有读取或写入访问权限(或两者)。

文本流被认为代表一组文本行,每行以新行字符结尾。根据运行应用程序的环境,可能会对文本流进行一些字符转换,以使某些特殊字符适应环境的文本文件规范。另一方面,二进制流是从物理介质写入或读取的字符序列,没有翻译,与读取或写入流的字符一一对应。

缓冲区是一块存储器,其中数据在物理读取或写入相关文件或设备之前被累积。流可以是完全缓冲,行缓冲或无缓冲。在完全缓冲的流上,在填充缓冲区时读取/写入数据,在线路缓冲的流上发生这种情况,当遇到换行符时,在无缓冲的流上,字符意图尽快读取/写入。

在打开时,流没有方向。一旦对它们执行输入/输出操作,它们就会变为byte-oriented或wide-oriented,具体取决于所执行的操作(通常,<cstdio>中定义的函数是byte-oriented,而<cwchar>中的函数是wide-oriented)。有关详细信息,请参阅cwchar


指示符

Streams具有确定的内部指示符,用于指定其当前状态,并影响对其执行的某些输入和输出操作的行为:

错误指示符 当与流相关的操作发生错误时,将设置此指示符。可以使用ferror功能检查此指示器,并可以通过调用clearerrfreopenrewind来重置此指示器。
文件结束指示符 设置时,表示使用流执行的上次读取或写入操作已到达文件结尾。可以使用feof函数进行检查,可以通过调用clearerrfreopen或调用任何重定位函数(rewindfseekfsetpos)来重置。
位置指示符 它是每个流的内部指针,指向下一个I/O操作中要读取或写入的下一个字符。它的值可以通过ftellfgetpos函数获得,并且可以使用rewindingfseekfsetpos重新定位函数来更改。

函数

文件操作:

(function )

remove

删除文件

rename

重命名文件

tmpfile

打开临时文件

tmpnam

生成临时文件名


文件访问:

(function )

fclose

关闭打开的文件流

fflush

刷新流

fopen

打开文件流

freopen

使用不同的文件或模式重新打开流

setbuf

设置缓冲流

setvbuf

改变缓冲流


格式化输入/输出:

(function )

fprintf

将格式化数据写入流

fscanf

从流中读取格式化数据

printf

将格式化数据打印到stdout

scanf

从stdin读取格式化数据

snprintf 

将格式化输出写入一定大小的缓冲区

sprintf

将格式化数据写入字符串

sscanf

从字符串读取格式化数据

vfprintf

将格式化数据从变量参数列表写入流

vfscanf 

将格式化数据从流读入变量参数列表

vprintf

将格式化数据从变量参数列表打印到stdout

vscanf 

将格式化数据读入变量参数列表

vsnprintf 

将格式化数据从变量参数列表写入一定大小的缓冲区

vsprintf

将格式化数据从变量参数列表写入字符串

vsscanf 

将格式化数据从字符串读入变量参数列表


字符输入/输出:

(function )

fgetc

从流中获取字符

fgets

从流中获取字符串

fputc

将字符写入流

fputs

将字符串写入流

getc

从流中获取字符

getchar

从stdin 中获取字符

gets

从stdin 中获取字符串

putc

将字符写入流

putchar

将字符写入stdout

puts

将字符串写入stdout

ungetc

将字符放回流中


直接输入/输出:

(function )

fread

从流中读取数据块

fwrite

写数据块到流


文件定位:

(function )

fgetpos

获取流中的当前位置

fseek

重新定位流位置指示符

fsetpos

设置流的位置指示符

ftell

获取流中的当前位置

rewind

将流的位置设置为开头


错误处理:

(function )

clearerr

清除错误指示符

feof

检查文件结束指示符

ferror

检查错误指示符

perror

打印错误消息


 

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/203997.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • pycharm 2022激活码[最新免费获取]「建议收藏」

    (pycharm 2022激活码)这是一篇idea技术相关文章,由全栈君为大家提供,主要知识点是关于2021JetBrains全家桶永久激活码的内容IntelliJ2021最新激活注册码,破解教程可免费永久激活,亲测有效,下面是详细链接哦~https://javaforall.net/100143.html1STL5S9V8F-eyJsa…

    2022年3月27日
    283
  • Matlab 非线性有约束规划的粒子群算法「建议收藏」

    Matlab 非线性有约束规划的粒子群算法「建议收藏」粒子群算法的基本认识简单介绍:通过群体中个体之间的协作和信息共享来寻找最优解。适用于连续函数极值问题,对于非线性,多峰问题均有较强的全局搜索能力。主要掌握两点1.粒子的速度和位置速度代表移动的快慢,位置代表移动的方向。位置对应每个自变量,速度一般设置为变量范围的10%~20%。2.粒子的更新规则具体实例下面展示matlab代码。clear;close;clc%%约束条件和目标函数构建fun=@(x)x(1)^2+x(2)^2+x(3)^2+8;bind1

    2022年6月1日
    44
  • win10eplan激活码破解步骤【中文破解版】

    (win10eplan激活码破解步骤)JetBrains旗下有多款编译器工具(如:IntelliJ、WebStorm、PyCharm等)在各编程领域几乎都占据了垄断地位。建立在开源IntelliJ平台之上,过去15年以来,JetBrains一直在不断发展和完善这个平台。这个平台可以针对您的开发工作流进行微调并且能够提供…

    2022年3月22日
    206
  • linux shell编程 if else 语句,case语句

    linux shell编程 if else 语句,case语句if-else语句#ifelse2.sh#判断两个参数的大小#!/bin/bashif[$1-ge$2] then   echo”$1>=$2″ else   echo”$1<$2"fi测试:多重if-else语句shell中的elseif语句,简写成elif#!/bin/bash#读入一个分数判断等

    2022年8月18日
    6
  • epoll的原理和使用方法

    epoll的原理和使用方法

    2021年12月1日
    66
  • Flume对接Kafka详细过程[通俗易懂]

    Flume对接Kafka详细过程[通俗易懂]一、为什么要集成Flume和Kafka一般使用Flume+Kafka架构都是希望完成实时流式的日志处理,后面再连接上Storm/SparkStreaming等流式实时处理技术,从而完成日志实时解析的目标。如果Flume直接对接实时计算框架,当数据采集速度大于数据处理速度,很容易发生数据堆积或者数据丢失,而kafka可以当做一个消息缓存队列,从广义上理解,把它当做一个数据库,可以存放一段时间的数据。因此数据从数据源到flume再到Kafka时,数据一方面可以同步到HDFS做离线计算,另一方面可以做实时计

    2022年6月23日
    33

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号