std::basic_string<CharT,Traits,Allocator>::find_first_not_of

Finds the first character equal to none of the characters in the given character sequence. The search considers only the range [pos,size()). If all characters in the range can be found in the given character sequence, npos will be returned.

# Declarations

size_type find_first_not_of( const basic_string& str,
size_type pos = 0 ) const;

(noexcept since C++11) (constexpr since C++20)

size_type find_first_not_of( const CharT* s,
size_type pos, size_type count ) const;

(constexpr since C++20)

size_type find_first_not_of( const CharT* s,
size_type pos = 0 ) const;

(constexpr since C++20)

size_type find_first_not_of( CharT ch, size_type pos = 0 ) const;

(noexcept since C++11) (constexpr since C++20)

template< class StringViewLike >
size_type
find_first_not_of( const StringViewLike& t,
size_type pos = 0 ) const noexcept(/* see below */);

(since C++17) (constexpr since C++20)

# Parameters

# Return value

Position of the found character or std::string::npos if no such character is found.

# Example

#include <iostream>
#include <string>
 
int main()
{
    // Permit uppercase letters, lowercase letters and numbers in macro names
    const char* pattern = "ABCDEFGHIJKLMNOPQRSTUVWXYZ"
                          "abcdefghijklmnopqrstuvwxyz"
                          "0123456789";
 
    std::string data = "1) %FIX, 2) %HACK, and 3) %TODO";
    const std::string replacement = "%DONE%";
 
    std::cout << "Before: " << data << '\n';
 
    for (std::string::size_type first{}, last{};
        (first = data.find('%', first)) != std::string::npos;
        first += replacement.size())
    {
        last = data.find_first_not_of(pattern, first + 1);
        if (last == std::string::npos)
            last = data.length();
 
        // Now first at '%' and last is one past end of the found substring
        data.replace(first, last - first, replacement);
    }
 
    std::cout << "After: " << data << '\n';
}

# Defect reports

DRApplied toBehavior as publishedCorrect behavior
LWG 847C++98there was no exception safety guaranteeadded strong exception safety guarantee
LWG 2064C++11overloads (3,4) were noexceptremoved
LWG 2946C++17overload (5) caused ambiguity in some casesavoided by making it a template
P1148R0C++11C++17noexcept for overloads (4,5) wereaccidentally dropped by LWG2064/LWG2946restored

# See also