money_get 클래스
클래스 템플릿은 형식 CharType
시퀀스를 통화 값으로 변환하는 것을 제어하는 로캘 패싯 역할을 할 수 있는 개체를 설명합니다.
구문
template <class CharType, class InputIterator = istreambuf_iterator<CharType>>
class money_get : public locale::facet;
매개 변수
CharType
로캘의 문자를 인코딩하기 위해 프로그램 내 사용하는 형식입니다.
InputIterator
get 함수가 입력을 읽어올 반복기의 형식입니다.
설명
모든 로캘 패싯과 마찬가지로, 고정 개체 ID에는 초기값 0이 저장되어 있습니다. 저장된 값에 액세스를 처음 시도하면 id에 고유한 양수 값이 저장됩니다.
생성자
생성자 | Description |
---|---|
money_get | 통화 값을 나타내는 시퀀스에서 숫자 값을 추출하는 데 사용되는 money_get 형식의 개체에 대한 생성자입니다. |
Typedef
형식 이름 | 설명 |
---|---|
char_type | 로캘에서 사용하는 문자를 설명하기 위해 사용하는 형식입니다. |
iter_type | 입력 반복기에 대해 설명하는 형식입니다. |
string_type | CharType 형식의 문자가 포함된 문자열을 설명하는 형식입니다. |
멤버 함수
멤버 함수 | 설명 |
---|---|
do_get | 통화 값을 나타내는 문자 시퀀스에서 숫자 값을 추출하기 위해 호출하는 가상 함수입니다. |
get | 통화 값을 나타내는 문자 시퀀스에서 숫자 값을 추출합니다. |
요구 사항
헤더:<로캘>
네임스페이스: std
money_get::char_type
로캘에서 사용하는 문자를 설명하기 위해 사용하는 형식입니다.
typedef CharType char_type;
설명
이 형식은 템플릿 매개 변수 CharType과 동일한 의미입니다.
money_get::d o_get
통화 값을 나타내는 문자 시퀀스에서 숫자 값을 추출하기 위해 호출하는 가상 함수입니다.
virtual iter_type do_get(iter_type first,
iter_type last,
bool Intl,
ios_base& Iosbase,
ios_base::iostate& State,
long double& val) const virtual iter_type do_get(iter_type first,
iter_type last,
bool Intl,
ios_base& Iosbase,
ios_base::iostate& State,
string_type& val) const
매개 변수
first
변환할 시퀀스의 시작 부분 주소를 지정하는 입력 반복기입니다.
last
변환할 시퀀스의 끝부분 주소를 지정하는 입력 반복기입니다.
국제공항
시퀀스에서 true
예상되는 통화 기호의 형식을 나타내는 부울 값입니다(국제인 경우, false
국내인 경우).
Iosbase
집합이 통화 기호가 선택 사항임을 나타낼 때 사용하는 형식 플래그입니다. 그 외의 경우 통화 기호는 필수 항목입니다.
State(상태)
작업 성공 여부에 따라 스트림 상태에 대해 적절한 비트 마스크 요소를 설정합니다.
val
변환된 시퀀스를 저장하는 문자열입니다.
Return Value
통화 입력 필드를 벗어난 범위에 있는 첫 번째 요소를 주소 지정하는 입력 반복기입니다.
설명
첫 번째 보호된 가상 구성원 함수는 비어 있지 않은 완전한 통화 입력 필드를 인식할 때까지 시퀀스 [ first
, last
)에서 처음 시작되는 순차 요소 일치를 시도합니다. 성공하면 이 필드를 하나 이상의 10진수 시퀀스로 변환하고, 필요에 따라 빼기 기호(-
)가 앞에 와 크기를 나타내고 결과를 string_type 개체 val에 저장합니다. 이 함수는 통화 입력 필드를 벗어난 범위에 있는 첫 번째 요소를 지정하는 반복기를 반환합니다. 그렇지 않으면 함수는 빈 시퀀스를 val에 저장하고 상태를 설정합니다ios_base::failbit
. 그리고 유효한 통화 입력 필드의 접두사를 벗어난 범위에 있는 첫 번째 요소를 지정하는 반복기를 반환합니다. 두 경우 모두 반환 값이 last
와 같으면 함수는 State
에서 ios_base::eofbit
를 설정합니다.
두 번째 가상 보호 멤버 함수는 첫 번째 함수와 동일하게 동작합니다. 성공하면 선택적으로 부호 있는 숫자 시퀀스를 형식 long double
값으로 변환하고 해당 값을 val에 저장합니다.
통화 입력 필드의 형식은 유효 호출< use_facet moneypunct CharType, intl>>(iosbase)에서 반환된 로캘 패싯<팩에 의해 결정됩니다. getloc).
특별한 사항
fac. neg_format은 필드 구성 요소가 나타나는 순서를 결정합니다.
fac. curr_symbol은 통화 기호를 구성하는 요소 시퀀스를 결정합니다.
fac. positive_sign은 양수 기호를 구성하는 요소 시퀀스를 결정합니다.
fac. negative_sign은 음수 기호를 구성하는 요소 시퀀스를 결정합니다.
fac. grouping은 숫자가 소수점 왼쪽으로 그룹화되는 방법을 결정합니다.
fac. thousands_sep는 소수점 왼쪽의 숫자 그룹을 구분하는 요소를 결정합니다.
fac. decimal_point는 소수 자릿수와 정수 자릿수를 구분하는 요소를 결정합니다.
fac. frac_digits는 소수점 오른쪽에 있는 유효 소수 자릿수의 수를 결정합니다.
frac_digits
에서 호출한 것보다 소수 자릿수가 많은 금액을 구문 분석할 때do_get
은 최대frac_digits
자를 사용한 후 구문 분석을 중지합니다.
부호 문자열(fac. negative_sign
또는 fac.positive_sign
)에 요소가 두 개 이상 있는 경우 첫 번째 요소만 일치합니다. 여기서 요소가 money_base::sign과 같은 요소가 형식 패턴(fac.neg_format
)에 나타납니다. 나머지 요소는 통화 입력 필드의 끝에서 일치 여부를 확인합니다. 어떤 문자열에도 통화 입력 필드의 다음 요소와 일치하는 첫 번째 요소가 없으면 부호 문자열을 빈 문자열로 가져오며 양수 부호를 사용합니다.
iosbase. flags & showbase 가 0이 아닌 문자열 fac입니다. curr_symbol
이 일치해야 하며, money_base::symbol과 동일한 요소가 형식 패턴에 나타납니다. 그렇지 않고 money_base::symbol이 형식 패턴 끝에 나오며 부호 문자열에서 일치 여부를 확인할 요소가 남아 있지 않으면 통화 기호의 일치 여부를 확인하지 않습니다. 그 외의 경우에는 필요에 따라 통화 기호의 일치 여부를 확인합니다.
통화 입력 필드의 값 부분에 fac. thousands_sep
의 인스턴스가 나오지 않으면(money_base::value와 동일한 요소가 형식 패턴에 나타남) 그룹화 제양ㄱ 조건이 적용되지 않습니다. 그렇지 않으면 fac. grouping에서 적용하는 모든 그룹화 제약 조건이 적용됩니다. 결과 숫자 시퀀스는 하위 순서 fac. frac_digits
소수 자릿수가 소수점 오른쪽에 있는 것으로 간주하는 정수를 나타냅니다.
money_base::space와 동일한 요소가 형식 패턴에 나타나는 위치(해당 요소가 형식 패턴의 끝이 아닌 위치에 나타나는 경우)에서 임의의 공백 일치 여부를 확인합니다. 그렇지 않으면 내부 공백 일치 여부를 확인하지 않습니다. ctype<CharType>>(iosbase)을 use_facet<경우 요소 ch는 공백으로 간주됩니다. getloc). is( ctype_base::space, ch)는 true
.
예시
do_get
을 호출하는 get에 대한 예제를 참조하세요.
money_get::get
통화 값을 나타내는 문자 시퀀스에서 숫자 값을 추출합니다.
iter_type get(iter_type first,
iter_type last,
bool Intl,
ios_base& Iosbase,
ios_base::iostate& State,
long double& val) const;
iter_type get(iter_type first,
iter_type last,
bool Intl,
ios_base& Iosbase,
ios_base::iostate& State,
string_type& val) const;
매개 변수
first
변환할 시퀀스의 시작 부분 주소를 지정하는 입력 반복기입니다.
last
변환할 시퀀스의 끝부분 주소를 지정하는 입력 반복기입니다.
국제공항
시퀀스에서 true
예상되는 통화 기호의 형식을 나타내는 부울 값입니다(국제인 경우, false
국내인 경우).
Iosbase
집합이 통화 기호가 선택 사항임을 나타낼 때 사용하는 형식 플래그입니다. 그 외의 경우 통화 기호는 필수 항목입니다.
State(상태)
작업 성공 여부에 따라 스트림 상태에 대해 적절한 비트 마스크 요소를 설정합니다.
val
변환된 시퀀스를 저장하는 문자열입니다.
Return Value
통화 입력 필드를 벗어난 범위에 있는 첫 번째 요소를 주소 지정하는 입력 반복기입니다.
설명
두 멤버 함수는 모두 do_get(first, last, Intl, Iosbase, State, val)
반환합니다.
예시
// money_get_get.cpp
// compile with: /EHsc
#include <locale>
#include <iostream>
#include <sstream>
using namespace std;
int main( )
{
locale loc( "german_germany" );
basic_stringstream< char > psz;
psz << use_facet<moneypunct<char, 1> >(loc).curr_symbol() << "-1.000,56";
basic_stringstream< char > psz2;
psz2 << "-100056" << use_facet<moneypunct<char, 1> >(loc).curr_symbol();
ios_base::iostate st = 0;
long double fVal;
psz.flags( psz.flags( )|ios_base::showbase );
// Which forced the READING the currency symbol
psz.imbue(loc);
use_facet < money_get < char > >( loc ).
get( basic_istream<char>::_Iter( psz.rdbuf( ) ),
basic_istream<char>::_Iter( 0 ), true, psz, st, fVal );
if ( st & ios_base::failbit )
cout << "money_get(" << psz.str( ) << ", intl = 1) FAILED"
<< endl;
else
cout << "money_get(" << psz.str( ) << ", intl = 1) = "
<< fVal/100.0 << endl;
use_facet < money_get < char > >( loc ).
get(basic_istream<char>::_Iter(psz2.rdbuf( )),
basic_istream<char>::_Iter(0), false, psz2, st, fVal);
if ( st & ios_base::failbit )
cout << "money_get(" << psz2.str( ) << ", intl = 0) FAILED"
<< endl;
else
cout << "money_get(" << psz2.str( ) << ", intl = 0) = "
<< fVal/100.0 << endl;
};
money_get::iter_type
입력 반복기에 대해 설명하는 형식입니다.
typedef InputIterator iter_type;
설명
이 형식은 템플릿 매개 변수 InputIterator와 동일한 의미입니다.
money_get::money_get
통화 값을 나타내는 시퀀스에서 숫자 값을 추출하는 데 사용되는 money_get
형식의 개체에 대한 생성자입니다.
explicit money_get(size_t _Refs = 0);
매개 변수
_심판
개체에 대한 메모리 관리의 유형을 지정하는 데 사용하는 정수 값입니다.
설명
_Refs 매개 변수 및 해당 중요도에 사용할 수 있는 값은 다음과 같습니다.
0: 개체를 포함하는 로캘에 의해 개체의 수명이 관리됩니다.
1: 개체의 수명을 수동으로 관리해야 합니다.
> 1: 이러한 값은 정의되지 않습니다.
소멸자는 보호되므로 직접적인 예제는 확인할 수 없습니다.
생성자는 로캘::facet(_Refs)를 사용하여 기본 개체를 초기화합니다.
money_get::string_type
CharType 형식의 문자가 포함된 문자열을 설명하는 형식입니다.
typedef basic_string<CharType, Traits, Allocator> string_type;
설명
이 형식은 클래스 템플릿 basic_string 특수화를 설명합니다.