std::ctype<CharT>:: widen, do_widen
|
헤더 파일에 정의됨
<locale>
|
||
|
public
:
CharT widen ( char c ) const ; |
(1) | |
|
public
:
const char * widen ( const char * beg, const char * end, CharT * dst ) const ; |
(2) | |
|
protected
:
virtual CharT do_widen ( char c ) const ; |
(3) | |
|
protected
:
virtual const char * do_widen ( const char * beg, const char * end, CharT * dst ) const ; |
(4) | |
do_widen
오버로드를 호출합니다. 오버로드 (1)은
do_widen
(
c
)
를 호출하고, 오버로드 (2)는
do_widen
(
beg, end, dst
)
를 호출합니다.
[
beg
,
end
)
의 모든 문자에 대해, 해당 확장 문자를
dst
가 가리키는 문자 배열의 연속적인 위치에 기록합니다.
확장(widening)은 항상 와이드 문자를 반환하지만, basic source character set (until C++23) basic character set (since C++23) 에 속하는 문자들만 고유하고 명확하게 정의된 확장 변환을 보장하며, 이는 역변환도 보장됩니다( narrow() 에 의해). 실제로는, 멀티바이트 표현이 단일 바이트인 모든 문자들은 일반적으로 해당 와이드 문자로 확장되며, 나머지 가능한 단일 바이트 값들은 일반적으로 동일한 플레이스홀더 값(일반적으로 CharT ( - 1 ) )로 매핑됩니다.
확장(widening)은 성공할 경우, is() 가 인식하는 모든 문자 분류 범위를 보존합니다.
목차 |
매개변수
| c | - | 변환할 문자 |
| dflt | - | 변환이 실패할 경우 반환할 기본값 |
| beg | - | 변환할 문자 배열의 첫 번째 문자를 가리키는 포인터 |
| end | - | 변환할 문자 배열의 끝 다음을 가리키는 포인터 |
| dst | - | 채울 문자 배열의 첫 번째 요소를 가리키는 포인터 |
반환값
예제
#include <iostream> #include <locale> void try_widen(const std::ctype<wchar_t>& f, char c) { wchar_t w = f.widen(c); std::cout << "The single-byte character " << +(unsigned char)c << " widens to " << +w << '\n'; } int main() { std::locale::global(std::locale("cs_CZ.iso88592")); auto& f = std::use_facet<std::ctype<wchar_t>>(std::locale()); std::cout << std::hex << std::showbase << "In Czech ISO-8859-2 locale:\n"; try_widen(f, 'a'); try_widen(f, '\xdf'); // German letter ß (U+00df) in ISO-8859-2 try_widen(f, '\xec'); // Czech letter ě (U+011b) in ISO-8859-2 std::locale::global(std::locale("cs_CZ.utf8")); auto& f2 = std::use_facet<std::ctype<wchar_t>>(std::locale()); std::cout << "In Czech UTF-8 locale:\n"; try_widen(f2, 'a'); try_widen(f2, '\xdf'); try_widen(f2, '\xec'); }
가능한 출력:
In Czech ISO-8859-2 locale: The single-byte character 0x61 widens to 0x61 The single-byte character 0xdf widens to 0xdf The single-byte character 0xec widens to 0x11b In Czech UTF-8 locale: The single-byte character 0x61 widens to 0x61 The single-byte character 0xdf widens to 0xffffffff The single-byte character 0xec widens to 0xffffffff
결함 보고서
다음의 동작 변경 결함 보고서들은 이전에 발표된 C++ 표준에 소급 적용되었습니다.
| DR | 적용 대상 | 게시된 동작 | 올바른 동작 |
|---|---|---|---|
| LWG 153 | C++98 |
widen
항상 오버로드 (4) 호출
|
해당 오버로드 호출 |
참고 항목
do_narrow
를 호출합니다
(public member function) |
|
|
문자를 확장합니다
(
std::basic_ios<CharT,Traits>
의 public member function)
|
|
|
가능한 경우 단일 바이트 narrow 문자를 wide 문자로 확장합니다
(function) |