std::string::compare() v C++

porovnat() je veřejná členská funkce třídy string. Porovnává hodnotu objektu string (nebo podřetězce) s posloupností znaků zadanou jeho argumenty.
Porovnat() může zpracovat více než jeden argument pro každý řetězec, takže lze zadat podřetězec podle jeho indexu a podle jeho délky.
Typ návratu: Compare() vrací celočíselnou hodnotu spíše než booleovskou hodnotu.
Různé syntaxe pro string::compare() :

    Syntaxe 1: Porovnává řetězec *this s řetězcem 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 : pokud *toto je delší než str nebo, první znak, který se neshoduje, je větší 

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;> }>

Výstup:

Geeks is smaller than forGeeks Geeks is equal to Geeks 
    Syntaxe 2: Porovnává maximálně, len znaky řetězce *this, počínaje indexem idx řetězcem str.
 int string::compare (size_type idx, size_type len, const string& str) const Throws out_of_range if index>size(). 

CPP




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

Výstup:

Here, Geeks are forGeeks 
    Syntaxe 3: Porovnává nejvýše, len znaky řetězce *tento začínající indexem idx s nejvýše, str_len znaky řetězce str začínající indexem 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>velikost(). Vyhodí mimo_rozsah, pokud 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;> }>

Výstup:

Welcome, to techcodeview.com World 
    Syntaxe 4: Porovná znaky řetězce *this se znaky C-string 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;> }>

Výstup:

Geeks is smaller than string techcodeview.com forGeeks is equal to string forGeeks 
    Syntaxe 5: Porovnává maximálně, len znaky řetězce *this, počínaje indexem idx se všemi znaky C-řetězce cstr.
 int string::compare (size_type idx, size_type len, const char* cstr) const 

Všimněte si, že cstr nemusí být nulový ukazatel (NULL).

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;> }>

Výstup:

Geeks are awesome people 
    Syntaxe 6: Porovnává maximálně znaky len řetězce *this, počínaje indexem idx se znaky chars_len znaků pole znaků chars.
 int string::compare (size_type idx, size_type len, const char* chars,  size_type chars_len)const 

Všimněte si, že znaky musí mít alespoň znaků chars_len. Znaky mohou mít libovolné hodnoty. „ “ tedy nemá žádný zvláštní význam.

CPP




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