Partilhar via


collate::compare

Compara duas sequências de caracteres de acordo com as regras faceta- específicas para igualdade ou 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 sequência a ser comparada.

  • _Last1
    Ponteiro para o elemento o mais recente na primeira sequência a ser comparada.

  • _First2
    Ponteiro para o primeiro elemento na segunda sequência a ser comparada.

  • _Last2
    Ponteiro para o elemento o mais recente na segunda sequência a ser comparada.

Valor de retorno

A função de membro:

  • 1 – se a primeira sequência compara menor que a segunda sequência.

  • +1 se a segunda sequência compara menor que a primeira sequência.

  • 0 se as sequências são equivalentes.

Comentários

A primeira sequência tiver menos compara se o elemento do par menor diferentes os mais cedo em sequências, ou, se nenhum par irregular existe, mas a primeira sequência for menor.

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;
}

Saída de Exemplo

-1
1

Requisitos

localidade <deCabeçalho: >

Namespace: std

Consulte também

Referência

Classe collate