constexpr bool
starts_with( std::basic_string_view<CharT,Traits> sv ) const noexcept;
| (1) | (since C++20) |
constexpr bool
starts_with( CharT ch ) const noexcept;
| (2) | (since C++20) |
constexpr bool
starts_with( const CharT* s ) const;
| (3) | (since C++20) |
Checks if the string begins with the given prefix. The prefix may be one of the following:
sv (which may be a result of implicit conversion from another std::basic_string).ch.s.All three overloads effectively return std::basic_string_view<CharT, Traits>(data(), size()).starts_with(x), where x is the parameter.
| sv | - | a string view which may be a result of implicit conversion from another std::basic_string |
| ch | - | a single character |
| s | - | a null-terminated character string |
true if the string begins with the provided prefix, false otherwise.
| Feature-test macro | Value | Std | Comment |
|---|---|---|---|
__cpp_lib_starts_ends_with | 201711L | (C++20) | String prefix and suffix checking: starts_with() and ends_with() |
#include <iostream>
#include <string>
#include <string_view>
template<typename PrefixType>
void test_prefix_print(const std::string& str, PrefixType prefix)
{
std::cout << '\'' << str << "' starts with '" << prefix << "': "
<< str.starts_with(prefix) << '\n';
}
int main()
{
std::boolalpha(std::cout);
auto helloWorld = std::string("hello world");
test_prefix_print(helloWorld, std::string_view("hello"));
test_prefix_print(helloWorld, std::string_view("goodbye"));
test_prefix_print(helloWorld, 'h');
test_prefix_print(helloWorld, 'x');
}Output:
'hello world' starts with 'hello': true 'hello world' starts with 'goodbye': false 'hello world' starts with 'h': true 'hello world' starts with 'x': false
|
(C++20) | checks if the string ends with the given suffix (public member function) |
|
(C++20) | checks if the string view starts with the given prefix (public member function of std::basic_string_view<CharT,Traits>) |
|
(C++20) | checks if the string view ends with the given suffix (public member function of std::basic_string_view<CharT,Traits>) |
|
(C++23) | checks if the string contains the given substring or character (public member function) |
|
(C++23) | checks if the string view contains the given substring or character (public member function of std::basic_string_view<CharT,Traits>) |
| compares two strings (public member function) |
|
| returns a substring (public member function) |
© cppreference.com
Licensed under the Creative Commons Attribution-ShareAlike Unported License v3.0.
https://en.cppreference.com/w/cpp/string/basic_string/starts_with