string::operator<
Znázorňuje použití string::operator < standardní šablonu knihovny (STL) funkci jazyka 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);
Poznámky
[!POZNÁMKA]
Názvy tříd/parametr v prototyp verze v záhlaví souboru neodpovídají.Některé byly upraveny, aby se zlepšila čitelnost.
Existují tři verze string::operator < funkce.Dvě funkce porovnat pole znaků zakončený proti basic_string.Jejich provedení této operace pomocí basic_string string::compare funkci a vrací hodnotu na základě výsledků porovnání funkce.Třetí funkce porovnává dvě proměnné basic_string pomocí string::compare funkce první proměnné basic_string.Další informace o Porovnat fungovat, najdete string::compare funkce.Všimněte si, že tento operátor nepracuje s ukazatel hodnotu NULL pro pole znaků.Je třeba zajistit, že pole znaků není NULL, než předáte provozovateli.
Příklad
// 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)
}
Požadavky
Záhlaví: <string>