locale::locale
Tworzy ustawienia regionalne, lub kopię ustawienia regionalne lub kopii ustawień regionalnych, gdzie zestaw reguł lub kategorii został zastąpiony przez zestaw reguł lub kategorii od innych regionalnych.
locale( );
explicit locale(
const char* _Locname,
category _Cat = all
);
explicit locale(
const string& _Locname
);
locale(
const locale& _Loc
);
locale(
const locale& _Loc,
const locale& _Other,
category _Cat
);
locale(
const locale& _Loc,
const char* _Locname,
category _Cat
);
template<class Facet>
locale(
const locale& _Loc,
const Facet* _Fac
);
Parametry
_Locname
Nazwa ustawienia regionalne._Loc
Ustawienia regionalne, które mają być skopiowane przy tworzeniu nowych ustawień regionalnych._Other
Ustawienia regionalne, z których można wybrać kategorię._Cat
Kategoria mają zostać podstawione do konstruowanej ustawień regionalnych._Fac
Aspekt mają zostać podstawione do konstruowanej ustawień regionalnych.
Uwagi
Pierwszy Konstruktor inicjuje obiekt odpowiadający globalnych ustawień regionalnych.Konstruktory drugiego i trzeciego zainicjować wszystkie kategorie ustawień regionalnych do zachowywać się w sposób zgodny z nazwy ustawień regionalnych _Locname.Kopiowanie pozostałych konstruktorów _Loc, z opisanymi wyjątkami:
locale(const locale& _Loc, const locale& _Other, category _Cat);
zastępuje z _Other te aspekty odpowiadające kategorii C, c, które &_Cat jest różna od zera.
locale(const locale& _Loc, const char* _Locname, category _Cat);
locale(const locale& _Loc, const string& _Locname, category _Cat);
zastępuje z locale(_Locname, _All) te aspekty odpowiadające kategorii C, c, które &_Cat jest różna od zera.
template<class Facet> locale(const locale& _Loc, Facet* _Fac);
zastępuje w (lub dodaje do) _Loc aspekt _Fac, jeśli _Fac nie jest pusty wskaźnik.
Jeśli nazwy ustawień regionalnych _Locname jest pusty wskaźnik lub innego powodu nieprawidłowy rzuca funkcja runtime_error.
Przykład
// locale_locale.cpp
// compile with: /EHsc
#include <locale>
#include <iostream>
#include <tchar.h>
using namespace std;
int main( ) {
// Second constructor
locale loc ( "German_germany" );
_TCHAR * s1 = _T("Das ist wei\x00dfzz."); // \x00df is the German sharp-s, it comes before z in the German alphabet
_TCHAR * s2 = _T("Das ist weizzz.");
int result1 = use_facet<collate<_TCHAR> > ( loc ).
compare (s1, &s1[_tcslen( s1 )-1 ], s2, &s2[_tcslen( s2 )-1 ] );
cout << isalpha (_T ( '\x00df' ), loc ) << result1 << endl;
// The first (default) constructor
locale loc2;
int result2 = use_facet<collate<_TCHAR> > ( loc2 ).
compare (s1, &s1[_tcslen( s1 )-1 ], s2, &s2[_tcslen( s2 )-1 ] );
cout << isalpha (_T ( '\x00df' ), loc2 ) << result2 << endl;
// Third constructor
locale loc3 (loc2,loc, _M_COLLATE );
int result3 = use_facet<collate<_TCHAR> > ( loc3 ).
compare (s1, &s1[_tcslen( s1 )-1 ], s2, &s2[_tcslen( s2 )-1 ] );
cout << isalpha (_T ( '\x00df' ), loc3 ) << result3 << endl;
// Fourth constructor
locale loc4 (loc2, "German_Germany", _M_COLLATE );
int result4 = use_facet<collate<_TCHAR> > ( loc4 ).
compare (s1, &s1[_tcslen( s1 )-1 ], s2, &s2[_tcslen( s2 )-1 ] );
cout << isalpha (_T ( '\x00df' ), loc4 ) << result4 << endl;
}
Przykładowe dane wyjściowe
1-1
01
0-1
0-1
Wymagania
Nagłówek:<ustawień regionalnych>
Przestrzeń nazw: std