Condividi tramite


collate::compare

Confronta due sequenze di caratteri in base alle regole facet- specifiche per uguaglianza o di disuguaglianza.

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

Parametri

  • _First1
    Puntatore al primo elemento nella prima sequenza da confrontare.

  • _Last1
    Puntatore all'ultimo elemento nella prima sequenza da confrontare.

  • _First2
    Puntatore al primo elemento nella seconda sequenza da confrontare.

  • _Last2
    Puntatore all'ultimo elemento nella seconda sequenza da confrontare.

Valore restituito

Funzione restituisce membro:

  • – 1 se la prima sequenza confronta minore della seconda sequenza.

  • +1 se la seconda sequenza confronta minore della prima sequenza.

  • 0 se le sequenze sono equivalenti.

Note

La prima sequenza confronta minore se è il più piccolo della coppia disuguale precedente in sequenze, o, se non la coppia disuguale esiste, ma la prima sequenza è più breve.

La funzione membro restituisce do_compare(_First1, _Last1, _First2, _Last2).

Esempio

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

Esempio di output

-1
1

Requisiti

intestazione: <locale>

Spazio dei nomi: deviazione standard

Vedere anche

Riferimenti

collate Class