Namespaces
Variants

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

From cppreference.net
constexpr bool ends_with ( basic_string_view sv ) const noexcept ;
(1) (seit C++20)
constexpr bool ends_with ( CharT ch ) const noexcept ;
(2) (seit C++20)
constexpr bool ends_with ( const CharT * s ) const ;
(3) (seit C++20)

Prüft, ob die String-Ansicht mit dem angegebenen Suffix endet, wobei

1) das Suffix ist ein String-View. Effektiv gibt zurück size ( ) >= sv. size ( ) && compare ( size ( ) - sv. size ( ) , npos, sv ) == 0 .
2) das Suffix ist ein einzelnes Zeichen. Effektiv gibt ! empty ( ) && Traits :: eq ( back ( ) , ch ) zurück.
3) das Suffix ist eine nullterminierte Zeichenkette. Effektiv gibt ends_with ( basic_string_view ( s ) ) zurück.

Inhaltsverzeichnis

Parameter

sv - eine String-Ansicht, die durch implizite Konvertierung von std::basic_string entstehen kann
ch - ein einzelnes Zeichen
s - eine nullterminierte Zeichenkette

Rückgabewert

true wenn der String-View mit dem bereitgestellten Suffix endet, false andernfalls.

Hinweise

Feature-Test Makro Wert Std Funktion
__cpp_lib_starts_ends_with 201711L (C++20) String-Präfix- und Suffix-Prüfung: starts_with() und ends_with()

Beispiel

#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
    );
}
**Übersetzungsdetails:** - "Run this code" wurde zu "Diesen Code ausführen" übersetzt - Alle HTML-Tags, Attribute und Formatierung wurden beibehalten - Code innerhalb der `
`-Tags wurde nicht übersetzt
- C++-spezifische Begriffe wie `assert`, `string_view`, `ends_with` etc. wurden nicht übersetzt
- Kommentare im Code wurden nicht übersetzt (da innerhalb von `
`-Tags)

Siehe auch

prüft, ob die String-View mit dem angegebenen Präfix beginnt
(öffentliche Elementfunktion)
prüft, ob der String mit dem angegebenen Präfix beginnt
(öffentliche Elementfunktion von std::basic_string<CharT,Traits,Allocator> )
(C++20)
prüft, ob der String mit dem angegebenen Suffix endet
(öffentliche Elementfunktion von std::basic_string<CharT,Traits,Allocator> )
(C++23)
prüft, ob der String die angegebene Teilzeichenkette oder das Zeichen enthält
(öffentliche Elementfunktion von std::basic_string<CharT,Traits,Allocator> )
(C++23)
prüft, ob die String-View die angegebene Teilzeichenkette oder das Zeichen enthält
(öffentliche Elementfunktion)
vergleicht zwei Views
(öffentliche Elementfunktion)