porównywać() jest publiczną funkcją członkowską klasy string. Porównuje wartość obiektu ciągu (lub podciągu) z sekwencją znaków określoną przez jego argumenty.
Funkcja Compare() może przetworzyć więcej niż jeden argument dla każdego ciągu, dzięki czemu można określić podciąg na podstawie jego indeksu i długości.
Typ zwrotu: Compare() zwraca wartość całkowitą zamiast wartości logicznej.
Różne składnie string::compare() :
- Składnia 1: Porównuje ciąg *this z ciągiem str.
int string::compare (const string& str) const Returns: 0 : if both strings are equal. A value <0 : if *this is shorter than str or, first character that doesn't match is smaller than str. A value>0 : jeśli *to jest dłuższe niż str lub pierwszy niepasujący znak jest większy>
CPP
// CPP code for demonstrating> // string::compare (const string& str) const> #include> using> namespace> std;> void> compareOperation(string s1, string s2)> {> >// returns a value <0 (s1 is smaller than s2)> >if>((s1.compare(s2)) <0)> >cout << s1 << ' is smaller than ' << s2 << endl;> >// returns 0(s1, is being compared to itself)> >if>((s1.compare(s1)) == 0)> >cout << s1 << ' is equal to ' << s1 << endl;> >else> >cout << 'Strings didn't match ';> > }> // Driver Code> int> main()> {> >string s1('Geeks');> >string s2('forGeeks');> >compareOperation(s1, s2);> > >return> 0;> }> |
>
>
Wyjście:
Geeks is smaller than forGeeks Geeks is equal to Geeks>
- Składnia 2: Porównuje co najwyżej długość znaków ciągu *this, zaczynając od indeksu idx z ciągiem str.
int string::compare (size_type idx, size_type len, const string& str) const Throws out_of_range if index>rozmiar().>
CPP
Różnica dat w Excelu
// CPP code to demonstrate> // int string::compare (size_type idx, size_type len,> // const string& str) const> #include> using> namespace> std;> void> compareOperation(string s1, string s2)> {> >// Compares 5 characters from index number 3 of s2 with s1> >if>((s2.compare(3, 5, s1)) == 0)> >cout << 'Here, '<< s1 << ' are ' << s2;> >else> >cout << 'Strings didn't match ';> }> // Driver Code> int> main()> {> >string s1('Geeks');> >string s2('forGeeks');> >compareOperation(s1, s2);> > >return> 0;> }> |
>
>
Wyjście:
wyloguj się z konta Google na Androidzie
Here, Geeks are forGeeks>
- Składnia 3: Porównuje co najwyżej długość znaków ciągu *this zaczynającego się od indeksu idx z maksymalnie str_len znaków łańcucha str rozpoczynającego się od indeksu str_idx.
int string::compare (size_type idx, size_type len, const string& str, size_type str_idx, size_type str_len) const Throws out_of_range if idx>rozmiar(). Wyrzuca out_of_range jeśli str_idx> str.size().>
CPP
// CPP code to demonstrate> // int string::compare (size_type idx, size_type len, const string&> // str, size_type str_idx, size_type str_len) const> #include> using> namespace> std;> void> compareOperation(string s1, string s2)> {> >// Compares 5 characters from index number 0 of s1 with> >// 5 characters from index 3 of s2> >if>((s1.compare(0, 5, s2, 3, 5)) == 0)> >cout << 'Welcome to ' << s1 << s2 << ' World';> >else> >cout << 'Strings didn't match ';> }> // Driver Code> int> main()> {> >string s1('Geeks');> >string s2('forGeeks');> >compareOperation(s1, s2);> > >return> 0;> }> |
>
>
Wyjście:
Welcome, to techcodeview.com World>
- Składnia 4: Porównuje znaki ciągu *this ze znakami ciągu C cstr.
int string::compare (const char* cstr) const>
CPP
// CPP code to demonstrate> // int string::compare (const char* cstr) const> #include> using> namespace> std;> void> compareOperation(string s1, string s2)> {> >// returns <0 (s1 < 'techcodeview.com')> >if>((s1.compare('techcodeview.com')) <0)> >cout << s1 << ' is smaller than string ' << 'techcodeview.com';> >//returns 0 (s2 is 'forgeeks')> >if>((s2.compare('forGeeks')) == 0)> >cout << endl << s2 << ' is equal to string ' << s2;> >else> >cout << 'Strings didn't match ';> > }> // Driver Code> int> main()> {> >string s1('Geeks');> >string s2('forGeeks');> >compareOperation(s1, s2);> > >return> 0;> }> |
>
>
Wyjście:
Geeks is smaller than string techcodeview.com forGeeks is equal to string forGeeks>
- Składnia 5: Porównuje co najwyżej len znaków łańcucha *this, zaczynając od indeksu idx ze wszystkimi znakami ciągu C cstr.
int string::compare (size_type idx, size_type len, const char* cstr) const>
Należy pamiętać, że cstr nie może być wskaźnikiem zerowym (NULL).
nieważne 0
CPP
// CPP code to demonstrate> // int string::compare (size_type idx, size_type len,> // const char* cstr) const> #include> using> namespace> std;> void> compareOperation(string s1)> {> >// Compares 5 characters from 0 index of s1 with 'Geeks'> >if>((s1.compare(0, 5, 'Geeks')) == 0)> >cout << s1 << ' are ' << 'awesome people';> > >else> >cout << 'Strings didn't match ';> > }> // Driver Code> int> main()> {> >string s1('Geeks');> >compareOperation(s1);> > >return> 0;> }> |
>
>
Wyjście:
Geeks are awesome people>
- Składnia 6: Porównuje co najwyżej długość znaków łańcucha *this, zaczynając od indeksu idx ze znakami chars_len tablicy znaków chars.
int string::compare (size_type idx, size_type len, const char* chars, size_type chars_len)const>
Pamiętaj, że znaki muszą mieć co najmniej znaki chars_len. Znaki mogą mieć dowolne wartości. Zatem „ ” nie ma specjalnego znaczenia.
CPP
piekło wywołania zwrotnego w javascript
// CPP code to demonstrate> // int string::compare (size_type idx, size_type len,> // const char* chars, size_type chars_len)const> #include> using> namespace> std;> void> compareOperation(string s1, string s2)> {> >// Compares 5 characters from 0 index of s1 with> >// 5 characters of string 'Geeks'> >if>((s1.compare(0, 5, 'Geeks', 5)) == 0)> >cout << 'This is ' << s1 << s2 ;> > >else> >cout << 'Strings didn't match ';> }> // Driver Code> int> main()> {> >string s1('Geeks');> >string s2('forGeeks');> >compareOperation(s1, s2);> > >return> 0;> }> |
>
>