std::basic_string_view<CharT,Traits>:: starts_with
From cppreference.net
<
cpp
|
string
|
basic string view
|
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)
|
检查字符串视图是否以指定后缀结尾
(公开成员函数) |
|
(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)
|
检查字符串视图是否包含指定子串或字符
(公开成员函数) |
|
比较两个视图
(公开成员函数) |