命名空间
变体
操作

std::ios_base

来自 cppreference.cn
< cpp‎ | io
 
 
 
 
定义于头文件 <ios>
class ios_base;

ios_base 类是一个多用途类,作为所有 I/O 流类的基类。它维护几种类型的数据:

1) 状态信息:流状态标志。
2) 控制信息:控制输入和输出序列格式以及内嵌区域设置的标志。
3) 私有存储:索引可扩展数据结构,允许 longvoid* 成员,可以实现为两个任意长度数组、一个两元素结构体数组或另一个容器。
4) 回调:在 imbue()std::basic_ios::copyfmt()~ios_base() 中调用的任意数量的用户定义函数。

典型的实现包含与 fmtflagsiostateopenmodeseekdir 的所有值相对应的成员常量(如下所示),维护当前精度、宽度和格式标志、异常掩码、缓冲区错误状态、保存回调的可调整大小容器、当前内嵌区域设置、私有存储以及用于 xalloc() 的静态整数变量。

目录

[编辑] 成员函数

构造对象
(protected member function) [编辑]
析构对象
(virtual public member function) [编辑]
赋值给流
(public member function) [编辑]
格式化
管理格式标志
(public member function) [编辑]
设置特定格式标志
(public member function) [编辑]
清除特定格式标志
(public member function) [编辑]
管理浮点运算的十进制精度
(public member function) [编辑]
管理字段宽度
(public member function) [编辑]
区域设置
设置区域设置
(public member function) [编辑]
返回当前区域设置
(public member function) [编辑]
内部可扩展数组
[静态]
返回一个程序范围内的唯一整数,可安全用作 pword()iword() 的索引
(public static member function) [编辑]
如有必要,调整私有存储的大小,并访问给定索引处的 long 元素
(public member function) [编辑]
如有必要,调整私有存储的大小,并访问给定索引处的 void* 元素
(public member function) [编辑]
杂项
注册事件回调函数
(public member function) [编辑]
设置 C++ 和 C I/O 库是否可互操作
(public static member function) [编辑]

成员类

流异常
(public member class) [编辑]
初始化标准流对象
(public member class) [编辑]

成员类型和常量

类型 解释
流打开模式类型

还定义了以下常量

常量 解释[编辑]
app 在每次写入前定位到流末尾[编辑]
二进制 二进制模式打开[编辑]
in 为读取打开[编辑]
out 为写入打开[编辑]
trunc 打开时丢弃流的内容[编辑]
ate 打开后立即定位到流末尾[编辑]
noreplace (C++23) 以独占模式打开[编辑]

(typedef) [编辑]
格式化标志类型

还定义了以下常量

常量 解释[编辑]
dec 对整数 I/O 使用十进制基数:参阅 std::dec[编辑]
oct 对整数 I/O 使用八进制基数:参阅 std::oct[编辑]
hex 对整数 I/O 使用十六进制基数:参阅 std::hex[编辑]
basefield dec | oct | hex。用于掩码操作[编辑]
left 左对齐(在右侧添加填充字符):参阅 std::left[编辑]
right 右对齐(在左侧添加填充字符):参阅 std::right[编辑]
internal 内部对齐(在内部指定点添加填充字符):参阅 std::internal[编辑]
adjustfield left | right | internal。用于掩码操作[编辑]
scientific 使用科学记数法生成浮点类型,如果与 fixed 结合,则使用十六进制记数法:参阅 std::scientific[编辑]
fixed 使用定点记数法生成浮点类型,如果与 scientific 结合,则使用十六进制记数法:参阅 std::fixed[编辑]
floatfield scientific | fixed。用于掩码操作[编辑]
boolalpha 以字母数字格式插入和提取 bool 类型:参阅 std::boolalpha[编辑]
showbase 为整数输出生成指示数字基数的 前缀,在货币 I/O 中要求货币指示符:参阅 std::showbase[编辑]
showpoint 对于浮点数输出,无条件生成小数点字符:参阅 std::showpoint[编辑]
showpos 为非负数字输出生成 + 字符:参阅 std::showpos[编辑]
skipws 在某些输入操作前跳过前导空白字符:参阅 std::skipws[编辑]
unitbuf 在每次输出操作后刷新输出:参阅 std::unitbuf[编辑]
uppercase 在某些输出操作中,将某些小写字母替换为其大写等效项:参阅 std::uppercase[编辑]

(typedef) [编辑]
流状态类型

还定义了以下常量

常量 解释[编辑]
goodbit 无错误[编辑]
badbit 不可恢复的流错误[编辑]
failbit 输入/输出操作失败(格式化或提取错误)[编辑]
eofbit 关联的输入序列已到达文件末尾[编辑]

(typedef) [编辑]
定位方向类型

还定义了以下常量

常量 解释[编辑]
beg 流的开始[编辑]
end 流的结束[编辑]
cur 流位置指示器的当前位置[编辑]

(typedef) [编辑]
指定事件类型
(enum) [编辑]
回调函数类型
(typedef) [编辑]
已弃用的成员类型
类型 解释
io_state (deprecated) 可像 iostate 一样使用的整数类型
open_mode (deprecated) 可像 openmode 一样使用的整数类型
seek_dir (deprecated) 可像 seekdir 一样使用的整数类型
streamoff (deprecated) 可像 off_type 一样使用的未指定类型,不一定是 std::streamoff
streampos (deprecated) 可像 pos_type 一样使用的未指定类型,不一定是 std::streampos
(C++17 前)

[编辑] 缺陷报告

下列更改行为的缺陷报告追溯地应用于以前出版的 C++ 标准。

缺陷报告 应用于 发布时的行为 正确的行为
LWG 1357
(N3110)
C++98 std::ios_base 为类型 openmodefmtflags
iostate 定义了 operator~operator&
operator|,违反了 BitmaskType 的要求[1]
移除了这些定义
  1. 一个 BitmaskType 需要自身支持位操作。位操作支持不应由外部提供。

[编辑] 参阅

管理任意流缓冲区
(类模板) [编辑]