Namespaces
Variants

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

From cppreference.net
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

注释

功能测试 标准 功能特性
__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.net").ends_with(".com"sv) == true
        && std::string_view("https://cppreference.net").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)
检查字符串视图是否包含给定子串或字符
(公开成员函数)
比较两个视图
(公开成员函数)