命名空间
变体
操作

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

来自 cppreference.com
 
 
 
 
constexpr bool ends_with( basic_string_view sv ) const noexcept;
(1) (自 C++20 起)
constexpr bool ends_with( CharT ch ) const noexcept;
(2) (自 C++20 起)
constexpr bool ends_with( const CharT* s ) const;
(3) (自 C++20 起)

检查字符串视图是否以给定的后缀结尾,其中

1) 后缀是一个字符串视图。实际上返回 size() >= sv.size() && compare(size() - sv.size(), npos, sv) == 0.
2) 后缀是一个单个字符。实际上返回 !empty() && Traits::eq(back(), ch).
3) 后缀是一个以空字符结尾的字符字符串。实际上返回 ends_with(basic_string_view(s)).

内容

[编辑] 参数

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

[编辑] 返回值

true 如果字符串视图以提供的后缀结尾,否则为 false.

[编辑] 注释

功能测试 Std 功能
__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) ends_with( basic_string_view sv )
        && std::string_view("https://cppreference.com").ends_with(".com"sv) == true
        && std::string_view("https://cppreference.com").ends_with(".org"sv) == false
 
        // (2) ends_with( CharT c )
        && std::string_view("C++20").ends_with('0') == true
        && std::string_view("C++20").ends_with('3') == false
 
        // (3) ends_with( const CharT* s )
        && std::string_view("string_view").ends_with("view") == true
        && std::string_view("string_view").ends_with("View") == false
    );
}

[编辑] 另请参阅

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