Difference between revisions of "cpp/string/basic string/contains"
From cppreference.com
< cpp | string | basic string
m (Reverted edits by 93.100.163.120 (talk) to last revision by Fruderica) |
Andreas Krug (Talk | contribs) m ({{c}}, capitalized 1st letter, fmt) |
||
(7 intermediate revisions by one user not shown) | |||
Line 1: | Line 1: | ||
− | {{cpp/string/basic_string/title | contains}} | + | {{cpp/string/basic_string/title|contains}} |
{{cpp/string/basic_string/navbar}} | {{cpp/string/basic_string/navbar}} | ||
{{dcl begin}} | {{dcl begin}} | ||
− | {{dcl | num=1 |since=c++23|1= | + | {{dcl|num=1|since=c++23|1= |
− | constexpr bool contains( std::basic_string_view<CharT,Traits> sv ) | + | constexpr bool |
− | + | contains( std::basic_string_view<CharT,Traits> sv ) const noexcept; | |
}} | }} | ||
− | {{dcl | num=2 |since=c++23|1= | + | {{dcl|num=2|since=c++23|1= |
− | constexpr bool contains( CharT | + | constexpr bool |
+ | contains( CharT ch ) const noexcept; | ||
}} | }} | ||
− | {{dcl | num=3 |since=c++23|1= | + | {{dcl|num=3|since=c++23|1= |
− | constexpr bool contains( const CharT* s ) const; | + | constexpr bool |
+ | contains( const CharT* s ) const; | ||
}} | }} | ||
{{dcl end}} | {{dcl end}} | ||
Line 16: | Line 18: | ||
Checks if the string contains the given substring. The substring may be one of the following: | Checks if the string contains the given substring. The substring may be one of the following: | ||
− | @1@ | + | @1@ A string view {{c|sv}} (which may be a result of implicit conversion from another {{tt|std::basic_string}}). |
− | @2@ | + | @2@ A single character {{c|ch}}. |
− | @3@ | + | @3@ A null-terminated character string {{c|s}}. |
All three overloads are equivalent to {{c|1=return find(x) != npos;}}, where {{tt|x}} is the parameter. | All three overloads are equivalent to {{c|1=return find(x) != npos;}}, where {{tt|x}} is the parameter. | ||
Line 24: | Line 26: | ||
===Parameters=== | ===Parameters=== | ||
{{par begin}} | {{par begin}} | ||
− | {{par | sv | a string view which may be a result of implicit conversion from another {{tt|std::basic_string}}}} | + | {{par|sv|a string view which may be a result of implicit conversion from another {{tt|std::basic_string}}}} |
− | {{par | | + | {{par|ch|a single character}} |
− | {{par | s | a null-terminated character string}} | + | {{par|s|a null-terminated character string}} |
{{par end}} | {{par end}} | ||
===Return value=== | ===Return value=== | ||
{{c|true}} if the string contains the provided substring, {{c|false}} otherwise. | {{c|true}} if the string contains the provided substring, {{c|false}} otherwise. | ||
+ | |||
+ | ===Notes=== | ||
+ | {{feature test macro|__cpp_lib_string_contains|{{tt|contains}} functions|std=C++23|value=202011L}} | ||
===Example=== | ===Example=== | ||
{{example | {{example | ||
− | + | |code= | |
+ | #include <iomanip> | ||
#include <iostream> | #include <iostream> | ||
+ | #include <string> | ||
#include <string_view> | #include <string_view> | ||
− | #include < | + | #include <type_traits> |
− | template <typename SubstrType> | + | template<typename SubstrType> |
− | void | + | void test_substring(const std::string& str, SubstrType subs) |
{ | { | ||
− | std:: | + | constexpr char delim = std::is_scalar_v<SubstrType> ? '\'' : '\"'; |
− | + | std::cout << std::quoted(str) | |
+ | << (str.contains(subs) ? " contains " | ||
+ | : " does not contain ") | ||
+ | << std::quoted(std::string{subs}, delim) << '\n'; | ||
} | } | ||
int main() | int main() | ||
{ | { | ||
− | std:: | + | using namespace std::literals; |
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | auto helloWorld = "hello world"s; | |
− | + | test_substring(helloWorld, "hello"sv); | |
+ | test_substring(helloWorld, "goodbye"sv); | ||
+ | test_substring(helloWorld, 'w'); | ||
+ | test_substring(helloWorld, 'x'); | ||
} | } | ||
− | + | |output= | |
− | + | "hello world" contains "hello" | |
− | + | "hello world" does not contain "goodbye" | |
− | + | "hello world" contains 'w' | |
− | + | "hello world" does not contain 'x' | |
}} | }} | ||
===See also=== | ===See also=== | ||
{{dsc begin}} | {{dsc begin}} | ||
− | {{dsc inc | cpp/string/basic_string/dsc starts_with}} | + | {{dsc inc|cpp/string/basic_string/dsc starts_with}} |
− | {{dsc inc | cpp/string/basic_string/dsc ends_with}} | + | {{dsc inc|cpp/string/basic_string/dsc ends_with}} |
− | {{dsc inc | cpp/string/basic_string/dsc find}} | + | {{dsc inc|cpp/string/basic_string/dsc find}} |
− | {{dsc inc | cpp/string/basic_string/dsc substr}} | + | {{dsc inc|cpp/string/basic_string/dsc substr}} |
+ | {{dsc inc|cpp/string/basic_string_view/dsc {{SUBPAGENAMEE}}}} | ||
{{dsc end}} | {{dsc end}} | ||
{{langlinks|de|es|fr|it|ja|pl|pt|ru|zh}} | {{langlinks|de|es|fr|it|ja|pl|pt|ru|zh}} |
Latest revision as of 00:24, 1 June 2023
constexpr bool contains( std::basic_string_view<CharT,Traits> sv ) const noexcept; |
(1) | (since C++23) |
constexpr bool contains( CharT ch ) const noexcept; |
(2) | (since C++23) |
constexpr bool contains( const CharT* s ) const; |
(3) | (since C++23) |
Checks if the string contains the given substring. The substring may be one of the following:
1) A string view sv (which may be a result of implicit conversion from another
std::basic_string
).2) A single character ch.
3) A null-terminated character string s.
All three overloads are equivalent to return find(x) != npos;, where x
is the parameter.
Contents |
[edit] Parameters
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 |
[edit] Return value
true if the string contains the provided substring, false otherwise.
[edit] Notes
Feature-test macro | Value | Std | Feature |
---|---|---|---|
__cpp_lib_string_contains |
202011L | (C++23) | contains functions
|
[edit] Example
Run this code
#include <iomanip> #include <iostream> #include <string> #include <string_view> #include <type_traits> template<typename SubstrType> void test_substring(const std::string& str, SubstrType subs) { constexpr char delim = std::is_scalar_v<SubstrType> ? '\'' : '\"'; std::cout << std::quoted(str) << (str.contains(subs) ? " contains " : " does not contain ") << std::quoted(std::string{subs}, delim) << '\n'; } int main() { using namespace std::literals; auto helloWorld = "hello world"s; test_substring(helloWorld, "hello"sv); test_substring(helloWorld, "goodbye"sv); test_substring(helloWorld, 'w'); test_substring(helloWorld, 'x'); }
Output:
"hello world" contains "hello" "hello world" does not contain "goodbye" "hello world" contains 'w' "hello world" does not contain 'x'
[edit] See also
(C++20) |
checks if the string starts with the given prefix (public member function) |
(C++20) |
checks if the string ends with the given suffix (public member function) |
finds the first occurrence of the given substring (public member function) | |
returns a substring (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> )
|