std::basic_string_view<CharT,Traits>::starts_with
出自cppreference.com
| |
(1) | (C++20 起) |
| |
(2) | (C++20 起) |
| |
(3) | (C++20 起) |
檢查字符串視圖是否始於給定前綴,其中
1) 前綴為字符串視圖。相當於返回
basic_string_view(data(), std::min(size(), sv.size())) == sv。2) 前綴為單個字符。相當於返回
!empty() && Traits::eq(front(), c)。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.com"sv.starts_with("http"sv) == true
&& "https://cppreference.com"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) |
檢查字符串視圖是否含有給定的子串或字符 (公開成員函數) |
| 比較兩個視圖 (公開成員函數) |