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

出自cppreference.com
 
 
 
 
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(), 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)
檢查字符串視圖是否終於給定後綴
(公開成員函數) [編輯]
檢查字符串是否始於給定前綴
(std::basic_string<CharT,Traits,Allocator> 的公開成員函數) [編輯]
(C++20)
檢查字符串是否終於給定後綴
(std::basic_string<CharT,Traits,Allocator> 的公開成員函數) [編輯]
(C++23)
檢查字符串是否含有給定的子串或字符
(std::basic_string<CharT,Traits,Allocator> 的公開成員函數) [編輯]
(C++23)
檢查字符串視圖是否含有給定的子串或字符
(公開成員函數) [編輯]
比較兩個視圖
(公開成員函數) [編輯]