std::literals::string_view_literals::operator""sv
Von cppreference.com
< cpp | string | basic string view
| Definiert in Header <string_view> |
||
| constexpr std::string_view operator ""sv( const char* str, std::size_t len ) noexcept; |
(1) | (seit C++17) |
| constexpr std::u8string_view operator ""sv( const char8_t* str, std::size_t len ) noexcept; |
(2) | (seit C++20) |
| constexpr std::u16string_view operator ""sv( const char16_t* str, std::size_t len ) noexcept; |
(3) | (seit C++17) |
| constexpr std::u32string_view operator ""sv( const char32_t* str, std::size_t len ) noexcept; |
(4) | (seit C++17) |
| constexpr std::wstring_view operator ""sv( const wchar_t* str, std::size_t len ) noexcept; |
(5) | (seit C++17) |
Erzeugt eine Zeichenkettenansicht eines Zeichenliterals.
1) Gibt zurück std::string_view{str, len}.
2) Gibt zurück std::u8string_view{str, len}.
3) Gibt zurück std::u16string_view{str, len}.
4) Gibt zurück std::u32string_view{str, len}.
5) Gibt zurück std::wstring_view{str, len}.
Inhalt |
[bearbeiten] Parameter
| str | - | Zeiger auf den Anfang des rohen Zeichen-Array-Literals |
| len | - | Länge des rohen Zeichen-Array-Literals |
[bearbeiten] Rückgabewert
Das std::basic_string_view Literal.
[bearbeiten] Hinweise
Diese Operatoren sind im Namespace std::literals::string_view_literals deklariert, wobei sowohl literals als auch string_view_literals Inline-Namespaces sind. Der Zugriff auf diese Operatoren kann über eine der folgenden Anweisungen erfolgen:
- using namespace std::literals,
- using namespace std::string_view_literals, oder
- using namespace std::literals::string_view_literals.
[bearbeiten] Beispiel
Führen Sie diesen Code aus
#include <iostream> #include <string_view> #include <typeinfo> void print_each_character(const std::string_view sw) { for (char c : sw) std::cout << (c == '\0' ? '@' : c); std::cout << '\n'; } int main() { using namespace std::literals; std::string_view s1 = "abc\0\0def"; std::string_view s2 = "abc\0\0def"sv; std::cout << "s1.size(): " << s1.size() << "; s1: "; print_each_character(s1); std::cout << "s2.size(): " << s2.size() << "; s2: "; print_each_character(s2); std::cout << "substr(1, 4): " << "abcdef"sv.substr(1, 4) << '\n'; auto value_type_info = []<typename T>(T) { using V = typename T::value_type; std::cout << "sizeof " << typeid(V).name() << ": " << sizeof(V) << '\n'; }; value_type_info("char A"sv); value_type_info(L"wchar_t ∀"sv); value_type_info(u8"char8_t ∆"sv); value_type_info(u"char16_t ∇"sv); value_type_info(U"char32_t ∃"sv); value_type_info(LR"(raw ⊞)"sv); }
Mögliche Ausgabe
s1.size(): 3; s1: abc s2.size(): 8; s2: abc@@def substr(1, 4): bcde sizeof char: 1 sizeof wchar_t: 4 sizeof char8_t: 1 sizeof char16_t: 2 sizeof char32_t: 4 sizeof wchar_t: 4
[bearbeiten] Siehe auch
konstruiert eine basic_string_view(öffentliche Member-Funktion) | |
| (C++14) |
konvertiert ein Zeichenkettenliteral in basic_string(function) |