std::ios_base::xalloc
From cppreference.com
| static int xalloc(); |
||
std::ios_base のプライベートストレージにある1つのlongと1つのvoid*要素にアクセスするために使用できる、一意(プログラム全体で)のインデックス値を返します。アクセスには、iword() および pword() を呼び出します。xalloc の呼び出しはメモリを割り当てません。
|
この関数はスレッドセーフです。複数のスレッドからの同時アクセスは、データ競合を引き起こしません。 |
(C++11以降) |
次に利用可能な一意のインデックスを実質的にインクリメントします。
目次 |
[編集] 戻り値
pword/iwordインデックスとして使用する一意の整数。
[編集] 例
派生ストリームオブジェクトの実行時型識別のために、基底クラスの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]
[編集] 不具合報告
以下の動作変更を伴う欠陥報告が、以前に公開されたC++標準に遡って適用されました。
| DR | 適用対象 | 公開された動作 | 正しい動作 |
|---|---|---|---|
| LWG 2143 | C++11 | xalloc はスレッドセーフではなかった |
スレッドセーフになりました |
[編集] 関連項目
| 必要に応じてプライベートストレージのサイズを変更し、指定されたインデックスの void* 要素にアクセスする (public メンバ関数) | |
| 必要に応じてプライベートストレージのサイズを変更し、指定されたインデックスの long 要素にアクセスする (public メンバ関数) |