Struct char_traits
La struct char_traits descrive gli attributi associati a un carattere.
Sintassi
template <class CharType>
struct char_traits;
Parametri
CharType
Tipo di dati elemento.
Osservazioni:
Lo struct modello descrive vari tratti di carattere per il tipo CharType
. Il modello di classe basic_string nonché diversi modelli di classe iostream, tra cui basic_ios, usare queste informazioni per modificare gli elementi di tipo CharType
. Un elemento di questo tipo non deve richiedere una costruzione o una distruzione esplicita. Deve fornire un costruttore predefinito, un costruttore di copia e un operatore di assegnazione con la semantica prevista. Una copia bit per bit deve avere lo stesso effetto di un'assegnazione. Nessuna delle funzioni membro di struct char_traits può generare eccezioni.
Typedef
Nome tipo | Descrizione |
---|---|
char_type | Tipo di carattere. |
int_type | Un tipo Integer che può rappresentare un carattere di tipo char_type o un carattere EOF. |
off_type | Un tipo Integer che può rappresentare offset tra posizioni in un flusso. |
pos_type | Un tipo Integer che può rappresentare posizioni in un flusso. |
state_type | Tipo che rappresenta lo stato di conversione per caratteri multibyte in un flusso. |
Funzioni membro
Funzione membro | Descrizione |
---|---|
assign | Assegna un valore del carattere a un altro. |
compare | Confronta un numero specificato di caratteri in due stringhe. |
copy | Copia un numero specificato di caratteri da una stringa a un'altra. Deprecato. Usare invece char_traits::_Copy_s. |
_Copy_s | Copia un numero specificato di caratteri da una stringa a un'altra. |
eof | Restituisce il carattere EOF. |
eq | Verifica se due caratteri char_type sono uguali. |
eq_int_type | Verifica se due caratteri rappresentati come int_type sono uguali. |
find | Cerca la prima occorrenza di un carattere specificato in un intervallo di caratteri. |
length | Restituisce la lunghezza di una stringa. |
lt | Verifica se un carattere è minore di un altro. |
move | Copia un numero specificato di caratteri in una sequenza in un'altra sequenza possibile di sovrapposizione. Deprecato. Usare invece char_traits::_Move_s. |
_Move_s | Copia un numero specificato di caratteri in una sequenza in un'altra sequenza possibile di sovrapposizione. |
not_eof | Verifica se un carattere è il carattere EOF. |
to_char_type | Converte un carattere int_type in quello char_type corrispondente e restituisce il risultato. |
to_int_type | Converte un carattere char_type in quello int_type corrispondente e restituisce il risultato. |
Requisiti
Header:<string>
Spazio dei nomi: std
char_traits::assign
Assegna un valore del carattere a un altro elemento o un intervallo di elementi in una stringa.
static void assign(char_type& _CharTo,
const char_type& _CharFrom);
static char_type *assign(char_type* strTo,
size_t _Num,
char_type _CharFrom);
Parametri
_ CharFrom Il carattere il cui valore deve essere assegnato.
_CharTo
L'elemento a cui deve essere assegnato il valore del carattere.
strTo
Stringa o matrice di caratteri ai cui elementi iniziali devono essere assegnati i valori dei caratteri.
_Num
Il numero di elementi a cui verranno assegnati i valori.
Valore restituito
La seconda funzione membro restituisce un puntatore alla stringa i cui primi elementi _Num sono stati assegnati valori di _CharFrom.
Esempio
// char_traits_assign.cpp
// compile with: /EHsc
#include <string>
#include <iostream>
int main( )
{
using namespace std;
// The first member function assigning
// one character value to another character
char ChTo = 't';
const char ChFrom = 'f';
cout << "The initial characters ( ChTo , ChFrom ) are: ( "
<< ChTo << " , " << ChFrom << " )." << endl;
char_traits<char>::assign ( ChTo , ChFrom );
cout << "After assigning, the characters ( ChTo , ChFrom ) are: ( "
<< ChTo << " , " << ChFrom << " )." << endl << endl;
// The second member function assigning
// character values to initial part of a string
char_traits<char>::char_type s1[] = "abcd-1234-abcd";
char_traits<char>::char_type* result1;
cout << "The target string s1 is: " << s1 << endl;
result1 = char_traits<char>::assign ( s1 , 4 , 'f' );
cout << "The result1 = assign ( s1 , 4 , 'f' ) is: "
<< result1 << endl;
}
The initial characters ( ChTo , ChFrom ) are: ( t , f ).
After assigning, the characters ( ChTo , ChFrom ) are: ( f , f ).
The target string s1 is: abcd-1234-abcd
The result1 = assign ( s1 , 4 , 'f' ) is: ffff-1234-abcd
char_traits::char_type
Tipo di carattere.
typedef CharType char_type;
Osservazioni:
Il tipo è un sinonimo del parametro di modello CharType
.
Esempio
Vedere l'esempio di copy per informazioni su come dichiarare e usare char_type
.
char_traits::compare
Confronta un numero specificato di caratteri in due stringhe.
static int compare(const char_type* str1,
const char_type* str2,
size_t _Num);
Parametri
str1
La prima di due stringhe da confrontare tra loro.
str2
La seconda di due stringhe da confrontare tra loro.
_Num
Il numero di elementi nelle stringhe da confrontare.
Valore restituito
Un valore negativo se la prima stringa è minore della seconda stringa, 0 se le due stringhe sono uguali o un valore positivo se la prima stringa è maggiore della seconda stringa.
Osservazioni:
Il confronto tra le stringhe viene eseguito elemento per elemento, testando prima l'uguaglianza, quindi, se in una coppia di elementi della sequenza risulta una disuguaglianza, vengono testate per stabilire qual è la minore.
Se due stringhe risultano uguali in un intervallo, ma una è più lunga dell'altra, la più corta delle due è minore di quella più lunga.
Esempio
// char_traits_compare.cpp
// compile with: /EHsc
#include <string>
#include <iostream>
int main() {
using namespace std;
char_traits<char>::char_type* s1 = "CAB";
char_traits<char>::char_type* s2 = "ABC";
char_traits<char>::char_type* s3 = "ABC";
char_traits<char>::char_type* s4 = "ABCD";
cout << "The string s1 is: " << s1 << endl;
cout << "The string s2 is: " << s2 << endl;
cout << "The string s3 is: " << s3 << endl;
cout << "The string s4 is: " << s4 << endl;
int comp1, comp2, comp3, comp4;
comp1 = char_traits<char>::compare ( s1 , s2 , 2 );
comp2 = char_traits<char>::compare ( s2 , s3 , 3 );
comp3 = char_traits<char>::compare ( s3 , s4 , 4 );
comp4 = char_traits<char>::compare ( s4 , s3 , 4 );
cout << "compare ( s1 , s2 , 2 ) = " << comp1 << endl;
cout << "compare ( s2 , s3 , 3 ) = " << comp2 << endl;
cout << "compare ( s3 , s4 , 4 ) = " << comp3 << endl;
cout << "compare ( s4 , s3 , 4 ) = " << comp4 << endl;
}
char_traits::copy
Copia un numero specificato di caratteri da una stringa a un'altra.
Questo metodo è potenzialmente non sicuro, poiché si basa sul chiamante per verificare che i valori passati siano corretti. È preferibile usare char_traits::_Copy_s.
static char_type *copy(char_type* _To,
const char_type* _From,
size_t _Num);
Parametri
_A
L'elemento all'inizio della matrice di stringhe o caratteri che deve ricevere la sequenza di caratteri copiata.
_Da
L'elemento all'inizio della matrice di stringhe o caratteri di origine da copiare.
_Num
Il numero di elementi da copiare.
Valore restituito
Il primo elemento copiato nella matrice di stringhe o caratteri che deve ricevere la sequenza di caratteri copiata.
Osservazioni:
Le sequenze di caratteri di origine e di destinazione non devono sovrapporsi.
Esempio
// char_traits_copy.cpp
// compile with: /EHsc /W3
#include <string>
#include <iostream>
int main( )
{
using namespace std;
char_traits<char>::char_type s1[] = "abcd-1234-abcd";
char_traits<char>::char_type s2[] = "ABCD-1234";
char_traits<char>::char_type* result1;
cout << "The source string is: " << s1 << endl;
cout << "The destination string is: " << s2 << endl;
// Note: char_traits::copy is potentially unsafe, consider
// using char_traits::_Copy_s instead.
result1 = char_traits<char>::copy ( s1 , s2 , 4 ); // C4996
cout << "The result1 = copy ( s1 , s2 , 4 ) is: "
<< result1 << endl;
}
The source string is: abcd-1234-abcd
The destination string is: ABCD-1234
The result1 = copy ( s1 , s2 , 4 ) is: ABCD-1234-abcd
char_traits::_Copy_s
Copia un numero specificato di caratteri da una stringa a un'altra.
static char_type *_Copy_s(
char_type* dest,
size_t dest_size,
const char_type* _From,
size_t count);
Parametri
dest
La matrice di stringhe o caratteri che deve ricevere la sequenza di caratteri copiata.
dest_size
Dimensione del dest. Se char_type
è char
, questa dimensione è espressa in byte. Se char_type
è wchar_t
, questa dimensione è espressa in parole.
_Da
La matrice di stringhe o caratteri di origine da copiare.
count
Il numero di elementi da copiare.
Valore restituito
La matrice di stringhe o caratteri che deve ricevere la sequenza di caratteri copiata.
Osservazioni:
Le sequenze di caratteri di origine e di destinazione non devono sovrapporsi.
Esempio
// char_traits__Copy_s.cpp
// compile with: /EHsc
#include <string>
#include <iostream>
int main( )
{
using namespace std;
char_traits<char>::char_type s1[] = "abcd-1234-abcd";
char_traits<char>::char_type s2[] = "ABCD-1234";
char_traits<char>::char_type* result1;
cout << "The source string is: " << s1 << endl;
cout << "The destination string is: " << s2 << endl;
result1 = char_traits<char>::_Copy_s(s1,
char_traits<char>::length(s1), s2, 4);
cout << "The result1 = _Copy_s(s1, "
<< "char_traits<char>::length(s1), s2, 4) is: "
<< result1 << endl;
}
The source string is: abcd-1234-abcd
The destination string is: ABCD-1234
The result1 = _Copy_s(s1, char_traits<char>::length(s1), s2, 4) is: ABCD-1234-abcd
char_traits::eof
Restituisce il carattere EOF.
static int_type eof();
Valore restituito
Il carattere EOF.
Osservazioni:
Valore che rappresenta la fine del file, ad esempio EOF o WEOF.
Lo standard C++ stabilisce che questo valore non deve corrispondere a un valore char_type
valido. Il compilatore Microsoft C++ applica questo vincolo per il tipo char
, ma non per il tipo wchar_t
. Nell'esempio che segue viene illustrato quanto descritto.
Esempio
// char_traits_eof.cpp
// compile with: /EHsc
#include <string>
#include <iostream>
int main()
{
using namespace std;
char_traits<char>::char_type ch1 = 'x';
char_traits<char>::int_type int1;
int1 = char_traits<char>::to_int_type(ch1);
cout << "char_type ch1 is '" << ch1 << "' and corresponds to int_type "
<< int1 << "." << endl << endl;
char_traits<char>::int_type int2 = char_traits<char>::eof();
cout << "The eof marker for char_traits<char> is: " << int2 << endl;
char_traits<wchar_t>::int_type int3 = char_traits<wchar_t>::eof();
cout << "The eof marker for char_traits<wchar_t> is: " << int3 << endl;
}
char_type ch1 is 'x' and corresponds to int_type 120.
The eof marker for char_traits<char> is: -1
The eof marker for char_traits<wchar_t> is: 65535
char_traits::eq
Verifica se due caratteri char_type
sono uguali.
static bool eq(const char_type& _Ch1, const char_type& _Ch2);
Parametri
_Ch1
Il primo di due caratteri di cui verificare l'uguaglianza.
_Ch2
Il secondo di due caratteri di cui verificare l'uguaglianza.
Valore restituito
true
se il primo carattere è uguale al secondo carattere; in caso contrario false
, .
Esempio
// char_traits_eq.cpp
// compile with: /EHsc
#include <string>
#include <iostream>
int main( )
{
using namespace std;
char_traits<char>::char_type ch1 = 'x';
char_traits<char>::char_type ch2 = 'y';
char_traits<char>::char_type ch3 = 'x';
// Testing for equality
bool b1 = char_traits<char>::eq ( ch1 , ch2 );
if ( b1 )
cout << "The character ch1 is equal "
<< "to the character ch2." << endl;
else
cout << "The character ch1 is not equal "
<< "to the character ch2." << endl;
// An equivalent and alternatively test procedure
if ( ch1 == ch3 )
cout << "The character ch1 is equal "
<< "to the character ch3." << endl;
else
cout << "The character ch1 is not equal "
<< "to the character ch3." << endl;
}
The character ch1 is not equal to the character ch2.
The character ch1 is equal to the character ch3.
char_traits::eq_int_type
Verifica se due caratteri rappresentati come int_type
sono uguali.
static bool eq_int_type(const int_type& _Ch1, const int_type& _Ch2);
Parametri
_Ch1
Primo dei due caratteri da testare per verificare l'uguaglianza come int_type
s.
_Ch2
Il secondo di due caratteri di cui verificare l'uguaglianza come int_type
.
Valore restituito
true
se il primo carattere è uguale al secondo carattere; in caso contrario false
, .
Esempio
// char_traits_eq_int_type.cpp
// compile with: /EHsc
#include <string>
#include <iostream>
int main( )
{
using namespace std;
char_traits<char>::char_type ch1 = 'x';
char_traits<char>::char_type ch2 = 'y';
char_traits<char>::char_type ch3 = 'x';
// Converting from char_type to int_type
char_traits<char>::int_type int1, int2 , int3;
int1 =char_traits<char>:: to_int_type ( ch1 );
int2 =char_traits<char>:: to_int_type ( ch2 );
int3 =char_traits<char>:: to_int_type ( ch3 );
cout << "The char_types and corresponding int_types are:"
<< "\n ch1 = " << ch1 << " corresponding to int1 = "
<< int1 << "."
<< "\n ch2 = " << ch2 << " corresponding to int1 = "
<< int2 << "."
<< "\n ch3 = " << ch3 << " corresponding to int1 = "
<< int3 << "." << endl << endl;
// Testing for equality of int_type representations
bool b1 = char_traits<char>::eq_int_type ( int1 , int2 );
if ( b1 )
cout << "The int_type representation of character ch1\n "
<< "is equal to the int_type representation of ch2."
<< endl;
else
cout << "The int_type representation of character ch1\n is "
<< "not equal to the int_type representation of ch2."
<< endl;
// An equivalent and alternatively test procedure
if ( int1 == int3 )
cout << "The int_type representation of character ch1\n "
<< "is equal to the int_type representation of ch3."
<< endl;
else
cout << "The int_type representation of character ch1\n is "
<< "not equal to the int_type representation of ch3."
<< endl;
}
The char_types and corresponding int_types are:
ch1 = x corresponding to int1 = 120.
ch2 = y corresponding to int1 = 121.
ch3 = x corresponding to int1 = 120.
The int_type representation of character ch1
is not equal to the int_type representation of ch2.
The int_type representation of character ch1
is equal to the int_type representation of ch3.
char_traits::find
Cerca la prima occorrenza di un carattere specificato in un intervallo di caratteri.
static const char_type* find(const char_type* str,
size_t _Num,
const char_type& _Ch);
Parametri
str
Il primo carattere della stringa in cui verrà eseguita la ricerca.
_Num
Il numero di posizioni, contando dalla prima, nell'intervallo in cui verrà eseguita la ricerca.
_Ch
Il carattere da cercare nell'intervallo.
Valore restituito
Un puntatore alla prima occorrenza del carattere specificato nell'intervallo se viene trovata una corrispondenza. In caso contrario, un puntatore Null.
Esempio
// char_traits_find.cpp
// compile with: /EHsc
#include <string>
#include <iostream>
int main( )
{
using namespace std;
const char* s1 = "f2d-1234-abcd";
const char* result1;
cout << "The string to be searched is: " << s1 << endl;
// Searching for a 'd' in the first 6 positions of string s1
result1 = char_traits<char>::find ( s1 , 6 , 'd');
cout << "The character searched for in s1 is: "
<< *result1 << endl;
cout << "The string beginning with the first occurrence\n "
<< "of the character 'd' is: " << result1 << endl;
// When no match is found the NULL value is returned
const char* result2;
result2 = char_traits<char>::find ( s1 , 3 , 'a');
if ( result2 == NULL )
cout << "The result2 of the search is NULL." << endl;
else
cout << "The result2 of the search is: " << result1
<< endl;
}
The string to be searched is: f2d-1234-abcd
The character searched for in s1 is: d
The string beginning with the first occurrence
of the character 'd' is: d-1234-abcd
The result2 of the search is NULL.
char_traits::int_type
Un tipo Integer che può rappresentare un carattere di tipo char_type
o un carattere EOF.
typedef long int_type;
Osservazioni:
È necessario digitare il cast di un valore di tipo CharType
a e quindi tornare a CharType
int_type
senza modificare il valore originale.
Esempio
Vedere l'esempio relativo a eq_int_type per informazioni su come dichiarare e usare int_type
.
char_traits::length
Restituisce la lunghezza di una stringa.
static size_t length(const char_type* str);
Parametri
str
Stringa C di cui si misura la lunghezza.
Valore restituito
Il numero di elementi della sequenza misurati, escluso il carattere di terminazione NULL.
Esempio
// char_traits_length.cpp
// compile with: /EHsc
#include <string>
#include <iostream>
int main( )
{
using namespace std;
const char* str1= "Hello";
cout << "The C-string str1 is: " << str1 << endl;
size_t lenStr1;
lenStr1 = char_traits<char>::length ( str1 );
cout << "The length of C-string str1 is: "
<< lenStr1 << "." << endl;
}
The C-string str1 is: Hello
The length of C-string str1 is: 5.
char_traits::lt
Verifica se un carattere è minore di un altro.
static bool lt(const char_type& _Ch1, const char_type& _Ch2);
Parametri
_Ch1
Il primo di due caratteri confrontati per verificare qual è il minore.
_Ch2
Il secondo di due caratteri confrontati per verificare qual è il minore.
Valore restituito
true
se il primo carattere è minore del secondo carattere; in caso contrario false
, .
Esempio
// char_traits_lt.cpp
// compile with: /EHsc
#include <string>
#include <iostream>
int main( )
{
using namespace std;
char_traits<char>::char_type ch1 = 'x';
char_traits<char>::char_type ch2 = 'y';
char_traits<char>::char_type ch3 = 'z';
// Testing for less than
bool b1 = char_traits<char>::lt ( ch1 , ch2 );
if ( b1 )
cout << "The character ch1 is less than "
<< "the character ch2." << endl;
else
cout << "The character ch1 is not less "
<< "than the character ch2." << endl;
// An equivalent and alternatively test procedure
if ( ch3 < ch2 )
cout << "The character ch3 is less than "
<< "the character ch2." << endl;
else
cout << "The character ch3 is not less "
<< "than the character ch2." << endl;
}
The character ch1 is less than the character ch2.
The character ch3 is not less than the character ch2.
char_traits::move
Copia un numero specificato di caratteri di una sequenza in un'altra sequenza che potrebbe sovrapporsi.
Questo metodo è potenzialmente non sicuro, poiché si basa sul chiamante per verificare che i valori passati siano corretti. È preferibile usare char_traits::_Move_s.
static char_type *move(char_type* _To,
const char_type* _From,
size_t _Num);
Parametri
_A
L'elemento all'inizio della matrice di stringhe o caratteri che deve ricevere la sequenza di caratteri copiata.
_Da
L'elemento all'inizio della matrice di stringhe o caratteri di origine da copiare.
_Num
Il numero di elementi da copiare dalla stringa di origine.
Valore restituito
Il primo elemento _To copiato nella stringa o nella matrice di caratteri di destinazione per ricevere la sequenza di caratteri copiata.
Osservazioni:
L'origine e la destinazione possono sovrapporsi.
Esempio
// char_traits_move.cpp
// compile with: /EHsc /W3
#include <string>
#include <iostream>
int main( )
{
using namespace std;
char_traits<char>::char_type sFrom1[] = "abcd-1234-abcd";
char_traits<char>::char_type sTo1[] = "ABCD-1234";
char_traits<char>::char_type* result1;
cout << "The source string sFrom1 is: " << sFrom1 << endl;
cout << "The destination stringsTo1 is: " << sTo1 << endl;
// Note: char_traits::move is potentially unsafe, consider
// using char_traits::_Move_s instead.
result1 = char_traits<char>::move ( sTo1 , sFrom1 , 4 ); // C4996
cout << "The result1 = move ( sTo1 , sFrom1 , 4 ) is: "
<< result1 << endl << endl;
// When source and destination overlap
char_traits<char>::char_type sToFrom2[] = "abcd-1234-ABCD";
char_traits<char>::char_type* result2;
cout << "The source/destination string sToFrom2 is: "
<< sToFrom2 << endl;
const char* findc = char_traits<char>::find ( sToFrom2 , 4 , 'c' );
// Note: char_traits::move is potentially unsafe, consider
// using char_traits::_Move_s instead.
result2 = char_traits<char>::move ( sToFrom2 , findc , 8 ); // C4996
cout << "The result2 = move ( sToFrom2 , findc , 8 ) is: "
<< result2 << endl;
}
The source string sFrom1 is: abcd-1234-abcd
The destination stringsTo1 is: ABCD-1234
The result1 = move ( sTo1 , sFrom1 , 4 ) is: abcd-1234
The source/destination string sToFrom2 is: abcd-1234-ABCD
The result2 = move ( sToFrom2 , findc , 8 ) is: cd-1234-4-ABCD
char_traits::_Move_s
Copia un numero specificato di caratteri di una sequenza in un'altra sequenza che potrebbe sovrapporsi.
static char_type *_Move_s(
char_type* dest,
size_t dest_size,
const char_type* _From,
size_t count);
Parametri
dest
L'elemento all'inizio della matrice di stringhe o caratteri che deve ricevere la sequenza di caratteri copiata.
dest_size
Dimensione del dest. Se char_type
è char
, il valore è espresso in byte. Se char_type
è wchar_t
, il valore è espresso in parole.
_Da
L'elemento all'inizio della matrice di stringhe o caratteri di origine da copiare.
count
Il numero di elementi da copiare dalla stringa di origine.
Valore restituito
Primo elemento copiato nella stringa o nella matrice di caratteri di destinazione per ricevere la sequenza di caratteri copiata.
Osservazioni:
L'origine e la destinazione possono sovrapporsi.
Esempio
// char_traits__Move_s.cpp
// compile with: /EHsc
#include <string>
#include <iostream>
int main( )
{
using namespace std;
char_traits<char>::char_type sFrom1[] = "abcd-1234-abcd";
char_traits<char>::char_type sTo1[] = "ABCD-1234";
char_traits<char>::char_type* result1;
cout << "The source string sFrom1 is: " << sFrom1 << endl;
cout << "The destination stringsTo1 is: " << sTo1 << endl;
result1 = char_traits<char>::_Move_s(sTo1,
char_traits<char>::length(sTo1), sFrom1, 4);
cout << "The result1 = _Move_s(sTo1, "
<< "char_traits<char>::length(sTo1), sFrom1, 4) is: "
<< result1 << endl << endl;
// When source and destination overlap
char_traits<char>::char_type sToFrom2[] = "abcd-1234-ABCD";
char_traits<char>::char_type* result2;
cout << "The source/destination string sToFrom2 is: "
<< sToFrom2 << endl;
const char* findc = char_traits<char>::find(sToFrom2, 4, 'c');
result2 = char_traits<char>::_Move_s(sToFrom2,
char_traits<char>::length(sToFrom2), findc, 8);
cout << "The result2 = _Move_s(sToFrom2, "
<< "char_traits<char>::length(sToFrom2), findc, 8) is: "
<< result2 << endl;
}
The source string sFrom1 is: abcd-1234-abcd
The destination stringsTo1 is: ABCD-1234
The result1 = _Move_s(sTo1, char_traits<char>::length(sTo1), sFrom1, 4) is: abcd-1234
The source/destination string sToFrom2 is: abcd-1234-ABCD
The result2 = _Move_s(sToFrom2, char_traits<char>::length(sToFrom2), findc, 8) is: cd-1234-4-ABCD
char_traits::not_eof
Verifica se un carattere è il carattere EOF (fine del file) o non lo è.
static int_type not_eof(const int_type& _Ch);
Parametri
_Ch
Il carattere rappresentato come int_type
da testare per verificare se è o non è il carattere EOF.
Valore restituito
Rappresentazione int_type
del carattere testato, se l'oggetto int_type
del carattere non è uguale a quello del carattere EOF.
Se il valore del carattere int_type
è uguale al valore EOF int_type
, false
.
Esempio
// char_traits_not_eof.cpp
// compile with: /EHsc
#include <string>
#include <iostream>
int main( ) {
using namespace std;
char_traits<char>::char_type ch1 = 'x';
char_traits<char>::int_type int1;
int1 = char_traits<char>:: to_int_type ( ch1 );
cout << "The char_type ch1 is " << ch1
<< " corresponding to int_type: "
<< int1 << "." << endl;
// EOF member function
char_traits <char>::int_type int2 = char_traits<char>::eof ( );
cout << "The eofReturn is: " << int2 << endl;
// Testing for EOF or another character
char_traits <char>::int_type eofTest1, eofTest2;
eofTest1 = char_traits<char>::not_eof ( int1 );
if ( !eofTest1 )
cout << "The eofTest1 indicates ch1 is an EOF character."
<< endl;
else
cout << "The eofTest1 returns: " << eofTest1
<< ", which is the character: "
<< char_traits<char>::to_char_type ( eofTest1 )
<< "." << endl;
eofTest2 = char_traits<char>::not_eof ( int2 );
if ( !eofTest2 )
cout << "The eofTest2 indicates int2 is an EOF character."
<< endl;
else
cout << "The eofTest1 returns: " << eofTest2
<< ", which is the character: "
<< char_traits<char>::to_char_type ( eofTest2 )
<< "." << endl;
}
The char_type ch1 is x corresponding to int_type: 120.
The eofReturn is: -1
The eofTest1 returns: 120, which is the character: x.
The eofTest2 indicates int2 is an EOF character.
char_traits::off_type
Un tipo Integer che può rappresentare offset tra posizioni in un flusso.
typedef streamoff off_type;
Osservazioni:
Il tipo è un intero con segno che descrive un oggetto in grado di archiviare un offset di byte interessato da varie operazioni di posizionamento del flusso. In genere è un sinonimo di streamoff e ha essenzialmente le stesse proprietà di quel tipo.
char_traits::p os_type
Un tipo Integer che può rappresentare posizioni in un flusso.
typedef streampos pos_type;
Osservazioni:
Il tipo descrive un oggetto in grado di archiviare tutte le informazioni necessarie per ripristinare un indicatore di posizione del file arbitrario all'interno di un flusso. In genere è un sinonimo di streampos e in ogni caso ha essenzialmente le stesse proprietà di quel tipo.
char_traits::state_type
Tipo che rappresenta lo stato di conversione per i caratteri multibyte in un flusso.
typedef implementation-defined state_type;
Osservazioni:
Il tipo descrive un oggetto che può rappresentare uno stato di conversione. In genere è un sinonimo di mbstate_t
e in ogni caso ha essenzialmente le stesse proprietà di quel tipo.
char_traits::to_char_type
Converte un carattere int_type
in quello char_type
corrispondente e restituisce il risultato.
static char_type to_char_type(const int_type& _Ch);
Parametri
_Ch
Il carattere int_type
da rappresentare come char_type
.
Valore restituito
Il carattere char_type
corrispondente al carattere int_type
.
Un valore di _Ch che non può essere rappresentato come tale restituisce un risultato non specificato.
Osservazioni:
Le operazioni di conversione to_int_type e to_char_type
sono l'una l'inverso dell'altra, in modo che:
to_int_type
( to_char_type
( x ) ) == x
per qualsiasi int_type
x e
to_char_type
( to_int_type
( x ) ) == x
per qualsiasi char_type
x.
Esempio
// char_traits_to_char_type.cpp
// compile with: /EHsc
#include <string>
#include <iostream>
int main( )
{
using namespace std;
char_traits<char>::char_type ch1 = 'a';
char_traits<char>::char_type ch2 = 'b';
char_traits<char>::char_type ch3 = 'a';
// Converting from char_type to int_type
char_traits<char>::int_type int1, int2 , int3;
int1 =char_traits<char>:: to_int_type ( ch1 );
int2 =char_traits<char>:: to_int_type ( ch2 );
int3 =char_traits<char>:: to_int_type ( ch3 );
cout << "The char_types and corresponding int_types are:"
<< "\n ch1 = " << ch1 << " corresponding to int1 = "
<< int1 << "."
<< "\n ch2 = " << ch2 << " corresponding to int1 = "
<< int2 << "."
<< "\n ch3 = " << ch3 << " corresponding to int1 = "
<< int3 << "." << endl << endl;
// Converting from int_type back to char_type
char_traits<char>::char_type rec_ch1;
rec_ch1 = char_traits<char>:: to_char_type ( int1);
char_traits<char>::char_type rec_ch2;
rec_ch2 = char_traits<char>:: to_char_type ( int2);
cout << "The recovered char_types and corresponding int_types are:"
<< "\n recovered ch1 = " << rec_ch1 << " from int1 = "
<< int1 << "."
<< "\n recovered ch2 = " << rec_ch2 << " from int2 = "
<< int2 << "." << endl << endl;
// Testing that the conversions are inverse operations
bool b1 = char_traits<char>::eq ( rec_ch1 , ch1 );
if ( b1 )
cout << "The recovered char_type of ch1"
<< " is equal to the original ch1." << endl;
else
cout << "The recovered char_type of ch1"
<< " is not equal to the original ch1." << endl;
// An equivalent and alternatively test procedure
if ( rec_ch2 == ch2 )
cout << "The recovered char_type of ch2"
<< " is equal to the original ch2." << endl;
else
cout << "The recovered char_type of ch2"
<< " is not equal to the original ch2." << endl;
}
The char_types and corresponding int_types are:
ch1 = a corresponding to int1 = 97.
ch2 = b corresponding to int1 = 98.
ch3 = a corresponding to int1 = 97.
The recovered char_types and corresponding int_types are:
recovered ch1 = a from int1 = 97.
recovered ch2 = b from int2 = 98.
The recovered char_type of ch1 is equal to the original ch1.
The recovered char_type of ch2 is equal to the original ch2.
char_traits::to_int_type
Converte un carattere char_type
in quello int_type
corrispondente e restituisce il risultato.
static int_type to_int_type(const char_type& _Ch);
Parametri
_Ch
Il carattere char_type
da rappresentare come int_type
.
Valore restituito
Il carattere int_type
corrispondente al carattere char_type
.
Osservazioni:
Le operazioni di conversione to_int_type
e to_char_type sono l'una l'inverso dell'altra, in modo che:
to_int_type
( to_char_type
( x ) ) == x
per qualsiasi int_type
x e
to_char_type
( to_int_type
( x ) ) == x
per qualsiasi char_type
x.
Esempio
// char_traits_to_int_type.cpp
// compile with: /EHsc
#include <string>
#include <iostream>
int main( )
{
using namespace std;
char_traits<char>::char_type ch1 = 'a';
char_traits<char>::char_type ch2 = 'b';
char_traits<char>::char_type ch3 = 'a';
// Converting from char_type to int_type
char_traits<char>::int_type int1, int2 , int3;
int1 =char_traits<char>:: to_int_type ( ch1 );
int2 =char_traits<char>:: to_int_type ( ch2 );
int3 =char_traits<char>:: to_int_type ( ch3 );
cout << "The char_types and corresponding int_types are:"
<< "\n ch1 = " << ch1 << " corresponding to int1 = "
<< int1 << "."
<< "\n ch2 = " << ch2 << " corresponding to int1 = "
<< int2 << "."
<< "\n ch3 = " << ch3 << " corresponding to int1 = "
<< int3 << "." << endl << endl;
// Converting from int_type back to char_type
char_traits<char>::char_type rec_ch1;
rec_ch1 = char_traits<char>:: to_char_type ( int1);
char_traits<char>::char_type rec_ch2;
rec_ch2 = char_traits<char>:: to_char_type ( int2);
cout << "The recovered char_types and corresponding int_types are:"
<< "\n recovered ch1 = " << rec_ch1 << " from int1 = "
<< int1 << "."
<< "\n recovered ch2 = " << rec_ch2 << " from int2 = "
<< int2 << "." << endl << endl;
// Testing that the conversions are inverse operations
bool b1 = char_traits<char>::eq ( rec_ch1 , ch1 );
if ( b1 )
cout << "The recovered char_type of ch1"
<< " is equal to the original ch1." << endl;
else
cout << "The recovered char_type of ch1"
<< " is not equal to the original ch1." << endl;
// An equivalent and alternatively test procedure
if ( rec_ch2 == ch2 )
cout << "The recovered char_type of ch2"
<< " is equal to the original ch2." << endl;
else
cout << "The recovered char_type of ch2"
<< " is not equal to the original ch2." << endl;
}
The char_types and corresponding int_types are:
ch1 = a corresponding to int1 = 97.
ch2 = b corresponding to int1 = 98.
ch3 = a corresponding to int1 = 97.
The recovered char_types and corresponding int_types are:
recovered ch1 = a from int1 = 97.
recovered ch2 = b from int2 = 98.
The recovered char_type of ch1 is equal to the original ch1.
The recovered char_type of ch2 is equal to the original ch2.
Vedi anche
Thread Safety in the C++ Standard Library (Sicurezza dei thread nella libreria standard C++)