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 строка:: сравнение функция и возврата true если функция сравнения возвращает значение 0.Третья функция сравнивает 2 переменной, используя basic_string строка:: сравнение функция первой basic_string переменной.Дополнительные сведения о сравнение функция см. в разделе строка:: сравнение функция.Видит, что этот оператор не работает с ПУСТЫМ указателем для массива символов.Необходимо будет убедиться, что массив символов НЕ равно null, прежде чем передать его предложению оператору.
Пример
// StringEqual.cpp
// compile with: /EHsc
// Illustrates how to use the operator== to test for
// equality of a basic_string variable and a
// null-terminated string. It also illustrates how to
// use the operator== to test for equality of two
// basic_string variables.
//
// Functions:
//
// operator== returns true if the basic_string and the null-
// terminated string are equal.
// operator== returns true if both basic_strings are equal.
//////////////////////////////////////////////////////////////////////
#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; //This specifies an empty initial-controlled sequence.
char CP1[]="abc";
char CP2[]="DEF";
char *CP3 = NULL;
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 << "S1==CP1 returned ";
trueFalse(S1==CP1); // False (calls function 1)
cout << "S1==CP2 returned ";
trueFalse(S1==CP2); // False (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); // True (calls function 3)
cout << "S1==S3 returned ";
trueFalse(S1==S3); // False (calls function 3)
cout << "S1==S4 returned ";
trueFalse(S1==S4); // False (calls function 3)
// Following use of the operator will cause the program to
// crash since CP3 is NULL.
// cout << "S1==CP3 returned ";
// trueFalse(S1==CP3);
}
Требования
заголовок: <Строка>