Namespaces
Variants

std::basic_string_view<CharT,Traits>:: find_first_not_of

From cppreference.net
constexpr size_type
find_first_not_of ( basic_string_view v, size_type pos = 0 ) const noexcept ;
(1) (自 C++17 起)
constexpr size_type
find_first_not_of ( CharT ch, size_type pos = 0 ) const noexcept ;
(2) (自 C++17 起)
constexpr size_type
find_first_not_of ( const CharT * s, size_type pos, size_type count ) const ;
(3) (自 C++17 起)
constexpr size_type
find_first_not_of ( const CharT * s, size_type pos = 0 ) const ;
(4) (自 C++17 起)

查找第一个不等于给定字符序列中任何字符的字符。

1) 在此视图中从位置 pos 开始查找第一个不等于 v 中任意字符的字符。
2) 等价于 find_first_not_of ( basic_string_view ( std:: addressof ( ch ) , 1 ) , pos )
3) 等价于 find_first_not_of ( basic_string_view ( s, count ) , pos )
4) 等价于 find_first_not_of ( basic_string_view ( s ) , pos )

目录

参数

v - 要搜索的视图
pos - 开始搜索的位置
count - 要比较的字符串长度
s - 指向要比较的字符串的指针
ch - 要比较的字符

返回值

返回第一个不等于给定字符串中任何字符的字符位置,若未找到此类字符则返回 std::string_view::npos

复杂度

最坏情况下为 O( size() * v. size() )。

示例

#include <string_view>
using namespace std::literals;
int main()
{
    static_assert(2 == "BCDEF"sv.find_first_not_of("ABC"));
                    //    ^
    static_assert(4 == "BCDEF"sv.find_first_not_of("ABC", 4));
                    //      ^
    static_assert(1 == "BCDEF"sv.find_first_not_of('B'));
                    //   ^
    static_assert(3 == "BCDEF"sv.find_first_not_of('D', 2));
                    //     ^
}

参见

在视图中查找字符
(公开成员函数)
查找子串的最后一次出现
(公开成员函数)
查找字符的首次出现
(公开成员函数)
查找字符的最后一次出现
(公开成员函数)
查找字符的最后一次缺失
(公开成员函数)
查找字符的首次缺失
( std::basic_string<CharT,Traits,Allocator> 的公开成员函数)