std::ios_base::iword
提供: cppreference.com
![]() | このページは、Google 翻訳を使って英語版から機械翻訳されました。 翻訳には誤りや奇妙な言い回しがあるかもしれません。文章の上にポインタをおくと、元の文章が見れます。誤りを修正して翻訳を改善する手助けをしてください。翻訳についての説明は、ここをクリックしてください。 |
long& iword(int index ); | ||
まず、確保したり、十分にlong有効なインデックスにするプライベートストレージ(
index
または別のインデックス可能なデータ構造の動的配列)をリサイズし、その後インデックスlong付き専用ストレージのindex
要素への参照を返します。. Original:
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
. The text has been machine-translated via Google Translate.
You can help to correct and verify the translation. Click here for instructions.
You can help to correct and verify the translation. Click here for instructions.
参照は、同じインデックスで
ios_base
から読み出す以降(iword()
への次のコールまで)同じ値が生成されるように、iword(index)への別のコールを含め、このcopyfmt()オブジェクト上の操作によって無効にされてもよいが、格納された値は保持されます。値は任意の目的に使用できます。要素のインデックスは、このxalloc()
の他のユーザーとの衝突が発生する可能性がありそうでなければ、ios_base
によって取得する必要があります。新しい要素が0に初期化され.Original:
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.The text has been machine-translated via Google Translate.
You can help to correct and verify the translation. Click here for instructions.
You can help to correct and verify the translation. Click here for instructions.
割り当てが失敗した場合、std::basic_ios<>::setstate(badbit)をスローすることがありstd::basic_ios::failure呼び出します
Original:
If allocation fails, calls std::basic_ios<>::setstate(badbit) which may throw std::basic_ios::failure
The text has been machine-translated via Google Translate.
You can help to correct and verify the translation. Click here for instructions.
You can help to correct and verify the translation. Click here for instructions.
目次 |
[編集]ノート
iwordストレージの典型的な使用例は、ユーザ定義するユーザ定義のI / Oマニピュレーターから
operator<<
とoperator>>
または標準ストリームに吹き込まれ、ユーザー定義の書式設定ファセットに情報(例えば、カスタム書式化フラグ)を渡すことです。.Original:
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.The text has been machine-translated via Google Translate.
You can help to correct and verify the translation. Click here for instructions.
You can help to correct and verify the translation. Click here for instructions.
[編集]パラメータ
index | - | 要素のインデックス値 Original: index value of the element The text has been machine-translated via Google Translate. You can help to correct and verify the translation. Click here for instructions. |
[編集]値を返します
要素への参照
Original:
reference to the element
The text has been machine-translated via Google Translate.
You can help to correct and verify the translation. Click here for instructions.
You can help to correct and verify the translation. Click here for instructions.
[編集]例外
badbitをを設定するときstd::ios_base::failureをスローすることがあります.
Original:
May throw std::ios_base::failure when setting the badbit.
The text has been machine-translated via Google Translate.
You can help to correct and verify the translation. Click here for instructions.
You can help to correct and verify the translation. Click here for instructions.
[編集]例
このコードを実行します
#include <iostream>#include <string> struct Foo {staticint foo_xalloc;std::string data; Foo(conststd::string& s): data(s){}}; // allocates the iword storage for use with Foo objectsint Foo::foo_xalloc= std::ios_base::xalloc(); // This user-defined operator<< prints the string in reverse if the iword holds 1std::ostream& operator<<(std::ostream& os, Foo& f){if(os.iword(Foo::foo_xalloc)==1)return os <<std::string(f.data.rbegin(), f.data.rend());elsereturn os << f.data;} // This I/O manipulator flips the number stored in iword between 0 and 1std::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*要素へのアクセスサイズを変更します Original: resizes the private storage if necessary and access to the void* element at the given index The text has been machine-translated via Google Translate. You can help to correct and verify the translation. Click here for instructions. (パブリックメンバ関数) | |
[静的] | pword()とiword()へのインデックスとして使用するのは安全ではプログラム全体で一意の整数を返します Original: returns a program-wide unique integer that is safe to use as index to pword() and iword() The text has been machine-translated via Google Translate. You can help to correct and verify the translation. Click here for instructions. (パブリック静的メンバ関数) |