Use rfind
overload that takes the search position pos
parameter, and pass zero for it:
std::string s = "tititoto"; if (s.rfind("titi", 0) == 0) { // pos=0 limits the search to the prefix // s starts with prefix }
Who needs anything else? Pure STL!
Many have misread this to mean “search backwards through the whole string looking for the prefix”. That would give the wrong result (e.g. string("tititito").rfind("titi")
returns 2 so when compared against == 0
would return false) and it would be inefficient (looking through the whole string instead of just the start). But it does not do that because it passes the pos
parameter as 0
, which limits the search to only match at that position or earlier. For example:
std::string test = "0123123"; size_t match1 = test.rfind("123"); // returns 4 (rightmost match) size_t match2 = test.rfind("123", 2); // returns 1 (skipped over later match) size_t match3 = test.rfind("123", 0); // returns std::string::npos (i.e. not found)