std::ios_base::iword
来自cppreference.com
该页由英文版wiki使用Google Translate机器翻译而来。
该翻译可能存在错误或用词不当。鼠标停留在文本上可以看到原版本。你可以帮助我们修正错误或改进翻译。参见说明请点击这里. |
long& iword( int index ); |
||
首先,分配或调整大小的的私人存储(long的动态数组或其他可转位数据结构)足以使
index
一个有效的索引,然后返回一个引用的私有存储与索引longindex
元素. 原文:
First, allocates or resizes the private storage (dynamic array of long or another indexable data structure) sufficiently to make
index
a valid index, then returns a reference to the long element of the private storage with the index index
. 参考这
ios_base
对象的任何操作无效,包括iword()
的另一个调用,但是存储的值将被保留,因此,阅读从iword(index)使用相同的索引后会产生相同的值,直到下一次调用copyfmt()。该值可以用于任何目的。 xalloc()
必须通过以下方式获得的元素的索引,否则本ios_base
与其他用户的碰撞可能会发生。新的元素被初始化为0.原文:
The reference may be invalidated by any operation on this
ios_base
object, including another call to iword()
, but the stored values are retained, so that reading from iword(index) with the same index later will produce the same value (until the next call to copyfmt()). The value can be used for any purpose. The index of the element must be obtained by xalloc()
, otherwise collisions with other users of this ios_base
may occur. New elements are initialized to 0.如果分配失败,调用std::basic_ios<>::setstate(badbit)可能会引发std::basic_ios::failure
原文:
If allocation fails, calls std::basic_ios<>::setstate(badbit) which may throw std::basic_ios::failure
目录 |
[编辑] 注释
典型使用的iword存储是通过用户定义的I / O操纵信息(如自定义格式标志)到用户自定义的
operator<<
和operator>>
或用户定义成标准的数据流格式方面充满.原文:
Typical use of iword storage is to pass information (e.g. custom formatting flags) from user-defined I/O manipulators to user-defined
operator<<
and operator>>
or to user-defined formatting facets imbued into standard streams.[编辑] 参数
index | - | 的元素的索引值
|
[编辑] 返回值
参考的元素
[编辑] 例外
可能会引发std::ios_base::failure时设置的badbit的.
原文:
May throw std::ios_base::failure when setting the badbit.
[编辑] 示例
#include <iostream> #include <string> struct Foo { static int foo_xalloc; std::string data; Foo(const std::string& s) : data(s) {} }; // allocates the iword storage for use with Foo objects int Foo::foo_xalloc = std::ios_base::xalloc(); // This user-defined operator<< prints the string in reverse if the iword holds 1 std::ostream& operator<<(std::ostream& os, Foo& f) { if(os.iword(Foo::foo_xalloc) == 1) return os << std::string(f.data.rbegin(), f.data.rend()); else return os << f.data; } // This I/O manipulator flips the number stored in iword between 0 and 1 std::ios_base& rev(std::ios_base& os) { os.iword(Foo::foo_xalloc) = !os.iword(Foo::foo_xalloc); return os; } int main() { Foo f("example"); std::cout << f << '\n' << rev << f << '\n' << rev << f << '\n'; }
输出:
example elpmaxe example
[编辑] 另请参阅
调整大小的私人存储,如果必要的,访问void*元素在给定的索引 原文: resizes the private storage if necessary and access to the void* element at the given index (公共成员函数) | |
[静态的]</div></div>
|
返回一个程序范围内唯一的整数,它是安全使用指数PWORD()和iword() 原文: returns a program-wide unique integer that is safe to use as index to pword() and iword() (公共静态成员函数) |