名前空間
変種
操作

std::basic_string<CharT,Traits,Allocator>::ends_with

提供: cppreference.com
< cpp‎ | string‎ | basic string
 
 
 
std::basic_string
 
bool ends_with(std::basic_string_view<CharT, Traits> x) const noexcept;
(1) (C++20以上)
bool ends_with(CharT x) const noexcept;
(2) (C++20以上)
bool ends_with(const CharT* x) const;
(3) (C++20以上)

文字列が指定された接尾辞で終わるかどうか調べます。

1) 接尾辞は文字列ビューです (別の std::basic_string から暗黙に変換された結果かもしれません)。
2) 接尾辞は単一の文字です。
3) 接尾辞は C スタイルの文字列です。

3つのオーバーロードはすべて実質的に std::basic_string_view<CharT, Traits>(data(), size()).ends_with(x); を返します。

目次

[編集] 引数

x - 文字列の末尾と比較する文字シーケンスまたは単一の文字。

[編集] 戻り値

文字列が指定された接尾辞で終わるならば true、そうでなければ false

[編集]

#include <iostream>
#include <string_view>
#include <string>
 
template <typename SuffixType>
void test_suffix_print(const std::string& str, SuffixType suffix)
{
    std::cout << '\'' << str << "' ends with '" << suffix << "': " <<
        str.ends_with(suffix) << '\n';
}
 
int main()
{
    std::boolalpha(std::cout);    
    auto helloWorld = std::string("hello world");
 
    test_suffix_print(helloWorld, std::string_view("world"));
 
    test_suffix_print(helloWorld, std::string_view("goodby"));
 
    test_suffix_print(helloWorld, 'd');
 
    test_suffix_print(helloWorld, 'x');
}

出力:

'hello world' ends with 'world': true
'hello world' ends with 'goodby': false
'hello world' ends with 'd': true
'hello world' ends with 'x': false

[編集] 関連項目

文字列が指定された接頭辞で始まるか調べます
(パブリックメンバ関数) [edit]
文字列ビューが指定された接頭辞で始まるか調べます
(std::basic_string_view<CharT,Traits>のパブリックメンバ関数) [edit]
(C++20)
文字列ビューが指定された接尾辞で終わるか調べます
(std::basic_string_view<CharT,Traits>のパブリックメンバ関数) [edit]
2つの文字列を比較します
(パブリックメンバ関数) [edit]
部分文字列を返します
(パブリックメンバ関数) [edit]