Compartilhar via


collate::compare

Compara duas seqüências de caracteres de acordo com as regras faceta- específicas para igualdade e desigualdade.

int compare(
   const CharType* _First1,
   const CharType* _Last1,
   const CharType* _First2,
   const CharType* _Last2
) const;

Parâmetros

  • _First1
    Ponteiro para o primeiro elemento na primeira seqüência seja comparada.

  • _Last1
    Ponteiro para o último elemento na primeira seqüência seja comparada.

  • _First2
    Ponteiro para o primeiro elemento na segunda seqüência seja comparada.

  • _Last2
    Ponteiro para o último elemento na segunda seqüência seja comparada.

Valor de retorno

Os retornos de função de membro:

  • 1 – se a primeira seqüência compara menos da segunda seqüência.

  • + segunda se a seqüência compara a menos que a primeira seqüência.

  • 0 se as seqüências são equivalentes.

Comentários

A primeira seqüência compara tem menos se o elemento menor em pares o contrário mais cedo em seqüências, ou, se nenhum registro diferente existir, mas a primeira seqüência é mais curta.

a função de membro retorna do_compare(_First1, _Last1, _First2, _Last2).

Exemplo

// collate_compare.cpp
// compile with: /EHsc
#include <locale>
#include <iostream>
#include <tchar.h>
using namespace std;

int main() {
   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 << result1 << endl;

   locale loc2 ( "C" );
   int result2 = use_facet<collate<_TCHAR> > ( loc2 ).
      compare (s1, &s1[_tcslen( s1 )-1 ],  s2, &s2[_tcslen( s2 )-1 ] );
   cout << result2 << endl;
}

A saída de exemplo

-1
1

Requisitos

Cabeçalho: <locale>

namespace: STD

Consulte também

Referência

collate Class