ロケールから同様に同じロケールから変換されるそのほかの文字シーケンスの辞書式の比較に使用できる文字列に文字列に変換します。
string_type transform(
const CharType* _First,
const CharType* _Last
) const;
パラメーター
_First
変換するシーケンスの最初の文字へのポインター。_Last
変換するシーケンスの最後の文字へのポインター。
戻り値
変換された文字シーケンスを含む文字列。
解説
このメンバー関数は do_transform (_First、_Last) を返します。
使用例
// collate_transform.cpp
// compile with: /EHsc
#include <locale>
#include <iostream>
#include <tchar.h>
using namespace std;
int main( )
{
locale loc ( "German_Germany" );
_TCHAR* s1 = _T("\x00dfzz abc.");
// \x00df is the German sharp-s (looks like beta),
// it comes before z in the alphabet
_TCHAR* s2 = _T("zzz abc.");
collate<_TCHAR>::string_type r1; // OK for typedef?
r1 = use_facet< collate<_TCHAR> > ( loc ).
transform (s1, &s1[_tcslen( s1 )-1 ]);
cout << r1 << endl;
basic_string<_TCHAR> r2 = use_facet< collate<_TCHAR> > ( loc ).
transform (s2, &s2[_tcslen( s2 )-1 ]);
cout << r2 << endl;
int result1 = use_facet<collate<_TCHAR> > ( loc ).compare
(s1, &s1[_tcslen( s1 )-1 ], s2, &s2[_tcslen( s2 )-1 ] );
cout << _tcscmp(r1.c_str( ),r2.c_str( )) << result1
<< _tcscmp(s1,s2) <<endl;
}
必要条件
ヘッダー: <locale>
名前空間: std