std::literals::string_view_literals::operator""sv - cppreference.com
提供: cppreference.com
<tbody> </tbody>
| ヘッダ |
||
|
|
(1) | (C++17以上) |
|
|
(2) | (C++20以上) |
|
|
(3) | (C++17以上) |
|
|
(4) | (C++17以上) |
|
|
(5) | (C++17以上) |
文字リテラルの文字列ビューを形成します。
1) std::string_view{str, len} を返します。
2) std::u8string_view{str, len} を返します。
3) std::u16string_view{str, len} を返します。
4) std::u32string_view{str, len} を返します。
5) std::wstring_view{str, len} を返します。
引数
| str | - | 生の文字配列リテラルの先頭を指すポインタ |
| len | - | 生の文字配列リテラルの長さ |
戻り値
string_view のリテラル。
ノート
これらの演算子は名前空間 std::literals::string_view_literals で宣言されています。 literals と string_view_literals は両方ともインライン名前空間です。 これらの演算子へのアクセスは using namespace std::literals, using namespace std::string_view_literals, using namespace std::literals::string_view_literals で得られます。
例
#include <string_view> #include <iostream> int main() { using namespace std::literals; std::string_view s1 = "abc\0\0def"; std::string_view s2 = "abc\0\0def"sv; std::cout << "s1: " << s1.size() << " \"" << s1 << "\"\n"; std::cout << "s2: " << s2.size() << " \"" << s2 << "\"\n"; }
出力例:
s1: 3 "abc" s2: 8 "abc^@^@def"