Namespaces
Variants

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

From cppreference.net
constexpr bool starts_with ( basic_string_view sv ) const noexcept ;
(1) (自 C++20 起)
constexpr bool starts_with ( CharT ch ) const noexcept ;
(2) (自 C++20 起)
constexpr bool starts_with ( const CharT * s ) const ;
(3) (自 C++20 起)

检查字符串视图是否以给定前缀开头,其中

1) 前缀是一个字符串视图。实际上返回 basic_string_view ( data ( ) , std:: min ( size ( ) , sv. size ( ) ) ) == sv
2) 前缀是单个字符。实际上返回 ! empty ( ) && Traits :: eq ( front ( ) , ch )
3) 前缀是一个以空字符结尾的字符串。实际上返回 starts_with ( basic_string_view ( s ) )

目录

参数

sv - 一个字符串视图,可能由 std::basic_string 隐式转换而来
ch - 单个字符
s - 以空字符结尾的字符串

返回值

如果字符串视图以提供的 前缀 开头,则为 true ,否则为 false

注释

功能测试 标准 功能特性
__cpp_lib_starts_ends_with 201711L (C++20) 字符串前缀与后缀检查: starts_with() ends_with()

示例

#include <cassert>
#include <string_view>
int main()
{
    using namespace std::literals;
    assert
    (""
        // (1) starts_with( basic_string_view )
        && "https://cppreference.net"sv.starts_with("http"sv) == true
        && "https://cppreference.net"sv.starts_with("ftp"sv) == false
        // (2) starts_with( CharT )
        && "C++20"sv.starts_with('C') == true
        && "C++20"sv.starts_with('J') == false
        // (3) starts_with( const CharT* )
        && std::string_view("string_view").starts_with("string") == true
        && std::string_view("string_view").starts_with("String") == false
    );
}

参见

(C++20)
检查字符串视图是否以指定后缀结尾
(公开成员函数)
检查字符串是否以指定前缀开头
( std::basic_string<CharT,Traits,Allocator> 的公开成员函数)
(C++20)
检查字符串是否以指定后缀结尾
( std::basic_string<CharT,Traits,Allocator> 的公开成员函数)
(C++23)
检查字符串是否包含指定子串或字符
( std::basic_string<CharT,Traits,Allocator> 的公开成员函数)
(C++23)
检查字符串视图是否包含指定子串或字符
(公开成员函数)
比较两个视图
(公开成员函数)