std::basic_ios

来自cppreference.com
< cpp‎ | io
 
 
 
 
在标头 <ios> 定义
template<

    class CharT,
    class Traits = std::char_traits<CharT>
> class basic_ios

    : public std::ios_base

std::basic_ios 提供设施,以对拥有 std::basic_streambuf 接口的对象赋予接口。数个 std::basic_ios 对象能指涉一个实际的 std::basic_streambuf 对象。

cpp/io/ios basestd-basic ios-inheritance.svg

继承图

提供了几个针对常用字符类型的 typedef:

在标头 <ios> 定义
类型 定义
std::ios std::basic_ios<char>
std::wios std::basic_ios<wchar_t>

成员类型

成员类型 定义
char_type CharT
traits_type TraitsTraits::char_type 不是 CharT 时程序非良构。
int_type Traits::int_type
pos_type Traits::pos_type
off_type Traits::off_type

公开成员函数

构造对象
(公开成员函数)
析构对象
(公开成员函数)
operator=
复制赋值运算符被弃置
(公开成员函数)
状态函数
检查是否没有发生错误,即是否可执行输入/输出操作
(公开成员函数)
检查是否到达了文件末尾
(公开成员函数)
检查是否发生了可恢复的错误
(公开成员函数)
检查是否已发生不可恢复的错误
(公开成员函数)
检查是否有错误发生(fail() 的同义词)
(公开成员函数)
检查是否没有发生错误(!fail() 的同义词)
(公开成员函数)
返回状态标志
(公开成员函数)
设置状态标志
(公开成员函数)
修改状态标志
(公开成员函数)
格式化
复制格式化信息
(公开成员函数)
管理填充字符
(公开成员函数)
杂项
管理异常掩码
(公开成员函数)
设置本地环境
(公开成员函数)
管理相关的流缓冲区
(公开成员函数)
管理绑定的流
(公开成员函数)
窄化字符
(公开成员函数)
拓宽字符
(公开成员函数)

受保护成员函数

初始化一个默认构造的 std::basic_ios
(受保护成员函数)
(C++11)
从另一 std::basic_ios 移动,除了 rdbuf
(受保护成员函数)
(C++11)
与另一 std::basic_ios 交换,除了 rdbuf
(受保护成员函数)
替换 rdbuf 而不清除其错误状态
(受保护成员函数)

继承自 std::ios_base

成员函数

格式化
管理格式标志
(std::ios_base 的公开成员函数)
设置特定格式标志
(std::ios_base 的公开成员函数)
清除特定格式的标志
(std::ios_base 的公开成员函数)
管理浮点操作的精度
(std::ios_base 的公开成员函数)
管理字段宽度
(std::ios_base 的公开成员函数)
本地环境
设置本地环境
(std::ios_base 的公开成员函数)
返回当前本地环境
(std::ios_base 的公开成员函数)
内部可扩展数组
[静态]
返回能安全用作 pword()iword() 的索引的程序范围内独有的整数
(std::ios_base 的公开静态成员函数)
若必要则调整私有存储的大小,并访问位于给定索引的 long 元素
(std::ios_base 的公开成员函数)
若需要则调整私有存储的大小,并访问位于给定索引的 void* 元素
(std::ios_base 的公开成员函数)
杂项
注册事件回调函数
(std::ios_base 的公开成员函数)
设置 C++ 和 C 的输入/输出库是否可以互操作
(std::ios_base 的公开静态成员函数)
成员类
流异常
(std::ios_base 的公开成员类)
初始化标准流对象
(std::ios_base 的公开成员类)

成员类型和常量

类型 解释

流打开模式类型

同时定义下列常量:

常量 解释
app 每次写入前寻位到流结尾
binary 二进制模式打开
in 为读打开
out 为写打开
trunc 在打开时舍弃流的内容
ate 打开后立即寻位到流结尾
noreplace (C++23) 以独占模式打开

(typedef)
格式化标志类型

亦定义下列常量:

常量 解释
dec 为整数输入/输出使用十进制底:见 std::dec
oct 为整数输入/输出使用八进制底:见 std::oct
hex 为整数输入/输出使用十六进制底:见 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 生成为整数输出指示数字基底的前缀,货币输入/输出中要求现金指示符:见 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)
指定事件类型
(枚举)
回调函数类型
(typedef)

注解

std::basic_ios 的直接实现仅储存以下成员(它们完全取决于模板形参,从而不能作为 std::ios_base 的一部分):

  • 用于填充的字符(参见 fill()
  • 绑定的流指针(参见 tie()
  • 关联的流缓冲区指针(参见 rdbuf()

实际实现各异:

Microsoft Visual Studio 就储存了这三个成员。

LLVM libc++ 少储存了一个成员:它将 rdbuf 指针储存为 ios_basevoid* 成员。

GNU libstdc++ 储存了 4 个额外的成员:三个缓存的刻面和一个用于标识填充是否已初始化的标记。