std::num_get
From cppreference.com
| ヘッダー <locale> で定義 |
||
| template< class CharT, |
||
std::num_get クラスは、数値の文字列表現を解析するための規則をカプセル化します。具体的には、bool、unsigned short、unsigned int、long、unsigned long、long long、unsigned long long(since C++11)、float、double、long double、および void* の各型がサポートされています。標準の書式設定入力演算子(例:cin >> n;)は、I/O ストリームのロケールの std::num_get ファセットを使用して、数値のテキスト表現を解析します。
継承図
std::num_get の特殊化が標準ライブラリによって提供されることが保証されていない場合(下記参照)、その get() および do_get() の動作は指定された通りに保証されません。
目次 |
[編集] 特殊化
標準ライブラリは、以下の特殊化を提供することが保証されています(これらは あらゆるロケールオブジェクトによって実装される必要があります)。
| ヘッダー
<locale> で定義 | |
| std::num_get<char> | ナロー文字列の数値を解析します。 |
| std::num_get<wchar_t> | ワイド文字列の数値を解析します。 |
さらに、標準ライブラリは、以下の型要件を満たすすべての特殊化を提供することも保証されています。
-
CharTは以下のいずれかです。- char,
- wchar_t、および
- 実装定義の 文字コンテナ型 で、iostream コンポーネント をインスタンス化できる文字の要件を満たすもの。
-
InputItは LegacyInputIterator の要件を満たす必要があります。
[編集] ネストされた型
| 型 | 定義 |
char_type
|
CharT
|
iter_type
|
InputIt
|
[編集] データメンバ
| メンバ | 説明 |
std::locale::id id [static] |
ファセットの識別子 |
[編集] メンバ関数
新しい num_get ファセットを構築します。(public member function) | |
do_getを呼び出します。(public member function) |
[編集] 保護されたメンバ関数
num_get ファセットを破棄します。(protected メンバ関数) | |
| [virtual] |
入力ストリームから数値を解析します。 (仮想 protected メンバ関数) |
[編集] 例
このコードを実行
#include <iostream> #include <iterator> #include <locale> #include <sstream> #include <string> int main() { std::string de_double = "1.234.567,89"; std::string us_double = "1,234,567.89"; // parse using streams std::istringstream de_in(de_double); de_in.imbue(std::locale("de_DE.UTF-8")); double f1; de_in >> f1; std::istringstream us_in(de_double); us_in.imbue(std::locale("en_US.UTF-8")); double f2; us_in >> f2; std::cout << "Parsing " << de_double << " as double gives " << std::fixed << f1 << " in de_DE locale and " << f2 << " in en_US\n"; // use the facet directly std::istringstream s3(us_double); s3.imbue(std::locale("en_US.UTF-8")); auto& f = std::use_facet<std::num_get<char>>(s3.getloc()); std::istreambuf_iterator<char> beg(s3), end; double f3; std::ios::iostate err; f.get(beg, end, s3, err, f3); std::cout << "parsing " << us_double << " as double using raw en_US facet gives " << f3 << '\n'; }
出力
Parsing 1.234.567,89 as double gives 1234567.890000 in de_DE locale and 1.234000 in en_US parsing 1,234,567.89 as double using raw en_US facet gives 1234567.890000
[編集] 不具合報告
以下の動作変更を伴う欠陥報告が、以前に公開されたC++標準に遡って適用されました。
| DR | 適用対象 | 公開された動作 | 正しい動作 |
|---|---|---|---|
| LWG 427 | C++98 | num_get は、任意の CharT を受け入れることが保証されていました。iostream コンポーネント をインスタンス化できる 文字の要件を満たす |
char、wchar_t、およびその他の実装定義 の文字型のみを受け入れることが保証されています。 |
| LWG 2392 | C++98 | num_put が受け入れることが保証できるのは、num_get によって受け入れられることが保証されています。 |
実装定義の 文字コンテナ型を受け入れることを保証できます。 |
[編集] 関連項目
| 数値の句読点ルールを定義する (クラステンプレート) | |
| 数値を文字列シーケンスとして出力するために書式設定する (クラステンプレート) | |
| 書式付きデータを抽出する ( std::basic_istream<CharT,Traits>のpublicメンバ関数) |