|
|
| ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
size_type find_first_of(const basic_string& str, size_type pos=0)const; | (1) | (noexcept since C++11) (constexpr since C++20) |
size_type find_first_of(const CharT* s, size_type pos, size_type count)const; | (2) | (constexpr since C++20) |
size_type find_first_of(const CharT* s, size_type pos=0)const; | (3) | (constexpr since C++20) |
size_type find_first_of( CharT ch, size_type pos=0)const; | (4) | (noexcept since C++11) (constexpr since C++20) |
template<class StringViewLike> size_type | (5) | (since C++17) (constexpr since C++20) |
Finds the first character equal to one of the characters in the given character sequence. The search considers only the range[pos, size()). If none of the characters in the given character sequence is present in the range,npos will be returned.
[s, s+ count). This range can include null characters.[s, s+ count) is not avalid range, the behavior is undefined.[s, s+ Traits::length(s)) is not avalid range, the behavior is undefined.Contents |
| str | - | string identifying characters to search for |
| pos | - | position at which to begin searching |
| count | - | length of character string identifying characters to search for |
| s | - | pointer to a character string identifying characters to search for |
| ch | - | character to search for |
| t | - | object (convertible tostd::basic_string_view) identifying characters to search for |
Position of the found character ornpos if no such character is found.
If an exception is thrown for any reason, this function has no effect (strong exception safety guarantee).
Traits::eq() is used to perform the comparison.
#include <cassert>#include <iostream>#include <string>#include <string_view> int main(){usingnamespace std::literals; std::string::size_type sz; // (1) sz="alignas"s.find_first_of("klmn"s);// └────────────────────────┘assert(sz==1); sz="alignof"s.find_first_of("wxyz"s);// no matchassert(sz==std::string::npos); // (2) sz="consteval"s.find_first_of("xyzabc",0,3);// no match (× are not targets) ×××assert(sz==std::string::npos); sz="consteval"s.find_first_of("xyzabc",0,6);// └───────────────────────────────┘assert(sz==0); // (3) sz="decltype"s.find_first_of("xyzabc");// └────────────────────────────┘assert(sz==2); // (4) sz="co_await"s.find_first_of('a');// └──────────────────────┘assert(sz==3); // (5) sz="constinit"s.find_first_of("int"sv);// └─────────────────────────┘assert(sz==2); std::cout<<"All tests passed.\n";}
Output:
All tests passed.
The following behavior-changing defect reports were applied retroactively to previously published C++ standards.
| DR | Applied to | Behavior as published | Correct behavior |
|---|---|---|---|
| LWG 847 | C++98 | there was no exception safety guarantee | added strong exception safety guarantee |
| LWG 2064 | C++11 | overloads(3,4) were noexcept | removed |
| LWG 2946 | C++17 | overload(5) caused ambiguity in some cases | avoided by making it a template |
| P1148R0 | C++11 C++17 | noexcept for overloads(4,5) were accidentally dropped by LWG2064/LWG2946 | restored |
| finds the first occurrence of the given substring (public member function)[edit] | |
| find the last occurrence of a substring (public member function)[edit] | |
| find first absence of characters (public member function)[edit] | |
| find last occurrence of characters (public member function)[edit] | |
| find last absence of characters (public member function)[edit] | |
| find first occurrence of characters (public member function of std::basic_string_view<CharT,Traits>)[edit] | |
| returns the length of the maximum initial segment that consists of only the characters found in another byte string (function)[edit] |