Partager via


string::operator<

Illustre comment utiliser la fonction de bibliothèque de types (STL) Standard de chaîne : : operator< dans Visual C++.

template<class _E, class _TYPE, class _A> inline
   bool operator<(const basic_string<_E, _TYPE, _A>& LString,
   const _E *RCharArray);
template<class _E, class _TYPE, class _A> inline
   bool operator<(const _E *LCharArray,
   const basic_string<_E, _TYPE, _A>& RString);
template<class _E, class _TYPE, class _A> inline
   bool operator<(const basic_string<_E, _TYPE, _A>& LString,
   const basic_string<_E, _TYPE, _A>& RString);

Notes

[!REMARQUE]

Les noms de classes/paramètre dans le prototype ne correspondent pas à la version du fichier d'en-tête.certains ont été modifiés pour améliorer la lisibilité.

Il existe trois versions de la fonction de chaîne : : operator< .deux des fonctions comparent un tableau de caractères se terminant par null contre basic_string.Ils exécutent cette opération à l'aide de la fonction et de retourner de chaîne : : comparez de basic_string une valeur en fonction de les résultats de la fonction de comparaison.La troisième fonction compare deux variables basic_string, à l'aide de la fonction de chaîne : : comparez de la première variable basic_string.Pour plus d'informations sur la fonction de comparez , consultez la fonction de chaîne : : comparez .Notez que cet opérateur ne fonctionne pas avec le pointeur NULL pour le tableau de caractères.Vous devez vous assurer que le tableau de caractères n'est pas NULL avant de les transmettre à l'opérateur.

Exemple

// StringLessThan.cpp
// compile with: /EHsc
// Illustrates how to use the operator< to compare
// a basic_string variable and a null-terminated
// string. It also illustrates how to use the
// operator< to compare two basic_string variables.
//
// Functions:
//
//    operator<    Returns true if the first parameter is less than the
//                 second.
//////////////////////////////////////////////////////////////////////

#pragma warning(disable:4786)
#include <string>
#include <iostream>

using namespace std ;

void trueFalse(int x)
{
  cout << (x? "True": "False") << endl;
}

int main()
{
   string S1="ABC";
   string S2="ABC";
   string S3="DEF";
   string S4="abc";
   char CP1[]="ABC";
   char CP2[]="DEF";
   char CP3[]="ABCD";

   cout << "S1 is " << S1 << endl;
   cout << "S2 is " << S2 << endl;
   cout << "S3 is " << S3 << endl;
   cout << "S4 is " << S4 << endl;
   cout << "CP1 is " << CP1 << endl;
   cout << "CP2 is " << CP2 << endl;
   cout << "CP3 is " << CP3 << endl;

   cout << "S1<CP1 returned ";
   trueFalse(S1<CP1);  // False    (calls function 1)

   cout << "S1<CP2 returned ";
   trueFalse(S1<CP2);  // True   (calls function 1)

   cout << "CP1<S1 returned ";
   trueFalse(CP1<S1);  // False    (calls function 2)

   cout << "CP2<S1 returned ";
   trueFalse(CP2<S1);  // False    (calls function 2)

   cout << "S1<S2 returned ";
   trueFalse(S1<S2);   // False    (calls function 3)

   cout << "S1<S3 returned ";
   trueFalse(S1<S3);   // True   (calls function 3)

   cout << "S1<S4 returned ";
   trueFalse(S1<S4);   // True   (calls function 3)

   cout << "S1<CP3 returned ";
   trueFalse(S1<CP3);  // True   (calls function 1)
}
  

Configuration requise

en-tête : <string>

Voir aussi

Concepts

Exemples de modèles Standard