命名空间
变体
操作

std::ios_base::pword

来自 cppreference.cn
< cpp‎ | io‎ | ios base
 
 
 
 
void*& pword( int index );

首先,分配或调整私有存储(void* 的动态数组或另一个可索引数据结构)的大小,使其足以让 index 成为有效索引,然后返回对私有存储中索引为 indexvoid* 元素的引用。

该引用可能因对该 ios_base 对象的任何操作(包括另一次调用 pword())而失效,但存储的值会被保留,因此稍后使用相同的索引从 pword(index) 读取将产生相同的值,直到下次调用 std::basic_ios::copyfmt()。该值可用于任何目的。元素的索引必须通过 xalloc() 获得,否则行为未定义。新元素初始化为空指针

如果函数失败(可能是由于分配失败导致)并且 *thisbasic_ios<> 对象或子对象的基类子对象,则调用 std::basic_ios<>::setstate(badbit),这可能会抛出 std::ios_base::failure

目录

[edit] 参数

index - 元素的索引值

[edit] 返回值

元素的引用。

[edit] 异常

设置 badbit 时可能抛出 std::ios_base::failure

[edit] 注意

如果 pword 中存储的指针需要管理,则可以使用 register_callback() 来安装在需要时执行深拷贝或释放的处理程序。

[edit] 示例

使用基类 pword 存储来运行时类型识别派生的流对象。

#include <iostream>
 
template<class CharT, class Traits = std::char_traits<CharT>>
class mystream : public std::basic_ostream<CharT, Traits>
{
public:
    static const int xindex;
 
    mystream(std::basic_ostream<CharT, Traits>& ostr) :
        std::basic_ostream<CharT, Traits>(ostr.rdbuf())
    {
        this->pword(xindex) = this;
    }
 
    void myfn()
    {
        *this << "[special handling for mystream]";
    }
};
 
// Each specialization of mystream obtains a unique index from xalloc()
template<class CharT, class Traits>
const int mystream<CharT, Traits>::xindex = std::ios_base::xalloc();
 
// This I/O manipulator will be able to recognize ostreams that are mystreams
// by looking up the pointer stored in pword
template<class CharT, class Traits>
std::basic_ostream<CharT, Traits>& mymanip(std::basic_ostream<CharT, Traits>& os)
{
    if (os.pword(mystream<CharT, Traits>::xindex) == &os)
        static_cast<mystream<CharT, Traits>&>(os).myfn();
    return os;
}
 
int main()
{
    std::cout << "cout, narrow-character test " << mymanip << '\n';
 
    mystream<char> myout(std::cout);
    myout << "myout, narrow-character test " << mymanip << '\n';
 
    std::wcout << "wcout, wide-character test " << mymanip << '\n';
 
    mystream<wchar_t> mywout(std::wcout);
    mywout << "mywout, wide-character test " << mymanip << '\n';
}

输出

cout, narrow-character test
myout, narrow-character test [special handling for mystream]
wcout, wide-character test
mywout, wide-character test [special handling for mystream]

[edit] 缺陷报告

以下行为变更缺陷报告被追溯应用于先前发布的 C++ 标准。

DR 应用于 已发布行为 正确行为
LWG 36 C++98 如果引用失效,存储的值可能不
会被保留
存储的值会被保留
直到下次调用 copyfmt()
LWG 41 C++98 该函数本身在失败时设置 badbit,
ios_base 不提供这样的接口
badbit 由 basic_ios 设置
(如果 *this 是其基类子对象)

[edit] 参见

如果必要,调整私有存储的大小,并访问给定索引处的 long 元素
(公共成员函数) [编辑]
[静态]
返回一个程序范围唯一的整数,可以安全地用作 pword()iword() 的索引
(公共静态成员函数) [编辑]