Struct char_traits
A struct char_traits descreve os atributos associados a um caractere.
template <class CharType>
struct char_traits;
CharType
O tipo de dados do elemento.
A struct de modelo descreve várias características de caractere para o tipo CharType
. O modelo de classe basic_string, bem como vários modelos de classes iostream, incluindo basic_ios, usam essas informações para manipular elementos do tipo CharType
. Esse tipo de elemento não deve exigir construção ou destruição explícita. Ele deve fornecer um construtor padrão, um construtor de cópia e um operador de atribuição com a semântica esperada. Uma cópia bit a bit deve ter o mesmo efeito que uma atribuição. Nenhuma das funções membro da struct char_traits pode gerar exceções.
Nome do tipo | Descrição |
---|---|
char_type | Um tipo de caractere. |
int_type | Um tipo de inteiro que pode representar um caractere do tipo char_type ou um caractere de EOF (final de arquivo). |
off_type | Um tipo de inteiro que pode representar compensações entre posições em um fluxo. |
pos_type | Um tipo de inteiro que pode representar posições em um fluxo. |
state_type | Um tipo que representa o estado de conversão de caracteres multibyte em um fluxo. |
Função de membro | Descrição |
---|---|
assign | Atribui um valor de caractere a outro. |
compare | Compara até um número especificado de caracteres em duas cadeias de caracteres. |
copy | Copia um número especificado de caracteres de uma cadeia de caracteres para outra. Preterido. Use char_traits::_Copy_s em vez disso. |
_Copy_s | Copia um número especificado de caracteres de uma cadeia de caracteres para outra. |
eof | Retorna o caractere de EOF (final de arquivo). |
eq | Testa se dois caracteres char_type são iguais. |
eq_int_type | Testa se dois caracteres representados como int_type s são iguais. |
find | Pesquisa a primeira ocorrência de um caractere especificado em um intervalo de caracteres. |
length | Retorna o comprimento de uma cadeia de caracteres. |
lt | Testa se um caractere é menor que outro. |
move | Copia um número especificado de caracteres em uma sequência para outra sequência possivelmente sobreposta. Preterido. Use char_traits::_Move_s em vez disso. |
_Move_s | Copia um número especificado de caracteres em uma sequência para outra sequência possivelmente sobreposta. |
not_eof | Testa se um caractere é o caractere EOF (final de arquivo). |
to_char_type | Converte um caractere int_type para o caractere char_type correspondente e retorna o resultado. |
to_int_type | Converte um caractere char_type para o caractere int_type correspondente e retorna o resultado. |
Cabeçalho:<string>
Namespace: std
Atribui um valor de caractere a outro ou para um intervalo de elementos em uma cadeia de caracteres.
static void assign(char_type& _CharTo,
const char_type& _CharFrom);
static char_type *assign(char_type* strTo,
size_t _Num,
char_type _CharFrom);
_ CharFrom O caractere cujo valor deve ser atribuído.
_CharTo
O elemento ao qual deve ser atribuído o valor de caractere.
strTo
A matriz de caracteres ou cadeia de caracteres a cujos elementos iniciais devem ser atribuídos valores de caracteres.
_Num
O número de elementos aos quais serão atribuídos valores.
A segunda função de membro retorna um ponteiro para a cadeia de caracteres cujos primeiros _Num elementos foram atribuídos com valores de _CharFrom.
// 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
Um tipo de caractere.
typedef CharType char_type;
O tipo é um sinônimo do parâmetro de modeloCharType
.
Veja o exemplo de copy que demonstra como declarar e usar o char_type
.
Compara até um número especificado de caracteres em duas cadeias de caracteres.
static int compare(const char_type* str1,
const char_type* str2,
size_t _Num);
str1
A primeira das duas cadeias de caracteres a serem comparadas entre si.
str2
A segunda das duas cadeias de caracteres a serem comparadas entre si.
_Num
O número de elementos nas cadeias de caracteres a serem comparados.
Um valor negativo se a primeira cadeia de caracteres for menor que a segunda cadeia de caracteres; 0 se as duas cadeias de caracteres forem iguais; ou um valor positivo se a primeira cadeia de caracteres for maior que a segunda cadeia de caracteres.
A comparação entre as cadeias de caracteres é feita por elemento, primeiro testando a igualdade e então, se um par de elementos na sequência tiver um teste não igual, eles são testados para menor que.
Se duas cadeias de caracteres comparem-se como iguais em um intervalo, mas uma for mais longa do que a outra, a mais curta das duas será menor que a mais longa.
// 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;
}
Copia um número especificado de caracteres de uma cadeia de caracteres para outra.
Esse método pode não ser seguro, pois depende do chamador para verificar se os valores passados estão corretos. Considere usar char_traits::_Copy_s em vez disso.
static char_type *copy(char_type* _To,
const char_type* _From,
size_t _Num);
_To
O elemento no início da matriz de cadeia de caracteres ou caractere direcionado para receber a sequência de caracteres copiada.
_From
O elemento no início da matriz de cadeia de caracteres ou caractere de origem a ser copiado.
_Num
O número de elementos a serem copiados.
O primeiro elemento copiado para a matriz de caracteres ou cadeia de caracteres destinada a receber a sequência de caracteres copiada.
As sequências de caracteres de origem e destino não devem se sobrepor.
// 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
Copia um número especificado de caracteres de uma cadeia de caracteres para outra.
static char_type *_Copy_s(
char_type* dest,
size_t dest_size,
const char_type* _From,
size_t count);
dest
A matriz de caractere ou cadeia de caracteres de destino para receber a sequência de caracteres copiada.
dest_size
O tamanho do dest. Se char_type
for char
, esse tamanho estará em bytes. Se char_type
for wchar_t
, esse tamanho estará em palavras.
_From
A matriz de caracteres ou cadeia de caracteres de origem a ser copiada.
count
O número de elementos a serem copiados.
A matriz de caractere ou cadeia de caracteres de destino para receber a sequência de caracteres copiada.
As sequências de caracteres de origem e destino não devem se sobrepor.
// 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
Retorna o caractere de EOF (final de arquivo).
static int_type eof();
O caractere EOF.
Um valor que representa o fim do arquivo (como EOF ou WEOF).
Os padrão C++ determina que esse valor não deve corresponder a um valor char_type
válido. O compilador Microsoft C++ impõe essa restrição para o tipo char
, mas não para o tipo wchar_t
. O exemplo abaixo demonstra isso.
// 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
Testa se dois caracteres char_type
são iguais.
static bool eq(const char_type& _Ch1, const char_type& _Ch2);
_Ch1
O primeiro de dois caracteres a serem testados quanto à igualdade.
_Ch2
O segundo de dois caracteres a serem testados quanto à igualdade.
true
se o primeiro caractere for igual ao segundo caractere; caso contrário false
.
// 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.
Testa se dois caracteres representados como int_type
s são iguais ou não.
static bool eq_int_type(const int_type& _Ch1, const int_type& _Ch2);
_Ch1
O primeiro dos dois caracteres a serem testados quanto à igualdade como int_type
s.
_Ch2
O segundo de dois caracteres a serem testados quanto à igualdade como int_type
s.
true
se o primeiro caractere for igual ao segundo caractere; caso contrário false
.
// 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.
Pesquisa a primeira ocorrência de um caractere especificado em um intervalo de caracteres.
static const char_type* find(const char_type* str,
size_t _Num,
const char_type& _Ch);
str
O primeiro caractere na cadeia de caracteres a ser pesquisado.
_Num
O número de posições, contando da primeira, no intervalo a ser pesquisado.
_Ch
O caractere a ser pesquisado no intervalo.
Um ponteiro para a primeira ocorrência do caractere especificado no intervalo se uma correspondência for encontrada; caso contrário, um ponteiro nulo.
// 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.
Um tipo de inteiro que pode representar um caractere do tipo char_type
ou um caractere de EOF (final de arquivo).
typedef long int_type;
Deve ser possível fazer a conversão de tipo de um valor do tipo CharType
para int_type
e, em seguida, de volta para CharType
sem alterar o valor original.
Veja o exemplo de eq_int_type para obter um exemplo de como declarar e usar int_type
.
Retorna o comprimento de uma cadeia de caracteres.
static size_t length(const char_type* str);
str
A cadeia de caracteres C cujo tamanho deve ser medido.
O número de elementos na sequência que está sendo medida, não incluindo o terminador nulo.
// 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.
Testa se um caractere é menor que outro.
static bool lt(const char_type& _Ch1, const char_type& _Ch2);
_Ch1
O primeiro de dois caracteres a serem testados quanto a serem menores que.
_Ch2
O segundo de dois caracteres a serem testados quanto a serem menores que.
true
se o primeiro caractere for menor que o segundo caractere; caso contrário false
.
// 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.
Copia um número especificado de caracteres em uma sequência para outra sequência possivelmente sobreposta.
Esse método pode não ser seguro, pois depende do chamador para verificar se os valores passados estão corretos. Considere usar char_traits::_Move_s em vez disso.
static char_type *move(char_type* _To,
const char_type* _From,
size_t _Num);
_To
O elemento no início da matriz de cadeia de caracteres ou caractere direcionado para receber a sequência de caracteres copiada.
_From
O elemento no início da matriz de cadeia de caracteres ou caractere de origem a ser copiado.
_Num
O número de elementos a serem copiados da cadeia de caracteres de origem.
O primeiro elemento _To copiado para a matriz de caracteres ou cadeia de caracteres destinada a receber a sequência de caracteres copiada.
A origem e o destino podem se sobrepor.
// 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
Copia um número especificado de caracteres em uma sequência para outra sequência possivelmente sobreposta.
static char_type *_Move_s(
char_type* dest,
size_t dest_size,
const char_type* _From,
size_t count);
dest
O elemento no início da matriz de cadeia de caracteres ou caractere direcionado para receber a sequência de caracteres copiada.
dest_size
O tamanho do dest. Se char_type
for char
, então isso estará em bytes. Se char_type
for wchar_t
, então isso estará em palavras.
_From
O elemento no início da matriz de cadeia de caracteres ou caractere de origem a ser copiado.
count
O número de elementos a serem copiados da cadeia de caracteres de origem.
O primeiro elemento dest copiado para a matriz de caracteres ou cadeia de caracteres destinada a receber a sequência de caracteres copiada.
A origem e o destino podem se sobrepor.
// 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
Testa se um caractere não é o caractere EOF (fim de arquivo) ou se é o EOF.
static int_type not_eof(const int_type& _Ch);
_Ch
O caractere representado como um int_type
a ser testado para determinar se ele é o caractere EOF ou não.
A representação int_type
do caractere testado, se o int_type
do caractere não for igual ao do caractere EOF.
Se o valor int_type
do caractere for igual ao valor do EOF int_type
, então false
.
// 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.
Um tipo de inteiro que pode representar compensações entre posições em um fluxo.
typedef streamoff off_type;
O tipo é um inteiro com sinal que descreve um objeto que pode armazenar um deslocamento de byte envolvido em várias operações de posicionamento de fluxo. Normalmente é um sinônimo de streamoff, mas tem essencialmente as mesmas propriedades que aquele tipo.
Um tipo de inteiro que pode representar posições em um fluxo.
typedef streampos pos_type;
O tipo descreve um objeto que pode armazenar todas as informações necessárias para restaurar um indicador de posição de arquivo arbitrária dentro de um fluxo. Normalmente é um sinônimo de streamoff, mas em qualquer caso tem essencialmente as mesmas propriedades que aquele tipo.
Um tipo que representa o estado de conversão para caracteres multibyte em um fluxo.
typedef implementation-defined state_type;
O tipo descreve um objeto que pode representar o estado da conversão. Normalmente é um sinônimo de mbstate_t
, mas em qualquer caso tem essencialmente as mesmas propriedades que aquele tipo.
Converte um caractere int_type
para o caractere char_type
correspondente e retorna o resultado.
static char_type to_char_type(const int_type& _Ch);
_Ch
O caractere int_type
a ser representado como um char_type
.
O caractere char_type
que corresponde ao caractere int_type
.
Um valor de _Ch que não pode ser representado como tal produz um resultado não especificado.
As operações de conversão to_int_type e to_char_type
são o inverso umas das outras, de modo que:
to_int_type
( to_char_type
( x ) ) == x
para qualquer int_type
x e
to_char_type
( to_int_type
( x ) ) == x
para qualquer char_type
x.
// 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.
Converte um caractere char_type
para o caractere int_type
correspondente e retorna o resultado.
static int_type to_int_type(const char_type& _Ch);
_Ch
O caractere char_type
a ser representada como um int_type
.
O caractere int_type
que corresponde ao caractere char_type
.
As operações de conversão to_int_type
e to_char_type são o inverso umas às outras, de modo que:
to_int_type
( to_char_type
( x ) ) == x
para qualquer int_type
x, e
to_char_type
( to_int_type
( x ) ) == x
para qualquer char_type
x.
// 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.