Поделиться через


string::operator<

Демонстрируется использование строка:: operator< Стандартная функция библиотеки стандартных шаблонов (STL) в 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);

Заметки

ПримечаниеПримечание

Имена класса и параметра в прототипе не соответствует версии в файле заголовка.Некоторые были изменены для улучшения удобочитаемости.

Версии 3 строка:: operator< функция.2 Из функций сравнивают null-завершенный массив символов для basic_string.Они выполняют данную операцию, используя basic_string строка:: сравнение функция и возвращая значение, основанное на результатах выполнения функции сравнения.Третья функция сравнивает 2 переменной, используя basic_string строка:: сравнение функция первой basic_string переменной.Дополнительные сведения о сравнение функция см. в разделе строка:: сравнение функция.Видит, что этот оператор не работает с ПУСТЫМ указателем для массива символов.Необходимо будет убедиться, что массив символов НЕ равно null, прежде чем передать его предложению оператору.

Пример

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

Требования

заголовок: <Строка>

См. также

Основные понятия

Образец библиотеки стандартных шаблонов