std::literals::string_literals::operator""s - cppreference.com
提供: cppreference.com
<tbody> </tbody> <tbody class="t-dcl-rev t-dcl-rev-num "> </tbody><tbody> </tbody> <tbody class="t-dcl-rev t-dcl-rev-num "> </tbody><tbody> </tbody> <tbody class="t-dcl-rev t-dcl-rev-num "> </tbody><tbody> </tbody> <tbody class="t-dcl-rev t-dcl-rev-num "> </tbody><tbody> </tbody>
| ヘッダ |
||
| (1) | ||
|
|
(C++14以上) (C++20未満) |
|
|
|
(C++20以上) | |
|
|
(2) | (C++20以上) |
| (3) | ||
|
|
(C++14以上) (C++20未満) |
|
|
|
(C++20以上) | |
| (4) | ||
|
|
(C++14以上) (C++20未満) |
|
|
|
(C++20以上) | |
| (5) | ||
|
|
(C++14以上) (C++20未満) |
|
|
|
(C++20以上) | |
所望の型の文字列リテラルを形成します。
1) std::string{str, len} を返します。
2) std::u8string{str, len} を返します。
3) std::u16string{str, len} を返します。
4) std::u32string{str, len} を返します。
5) std::wstring{str, len} を返します。
引数
| str | - | 生の文字配列リテラルの先頭を指すポインタ |
| len | - | 生の文字配列リテラルの長さ |
戻り値
文字列リテラル。
ノート
これらの演算子は名前空間 std::literals::string_literals で宣言されています。 literals と string_literals は両方ともインライン名前空間です。 これらの演算子へのアクセスは using namespace std::literals, using namespace std::string_literals, using namespace std::literals::string_literals で得られます。
秒のリテラルを表すために std::chrono::duration も operator""s を定義していますが、そちらは算術リテラルです。 10.0s および 10s は10秒ですが、 "10"s は文字列です。
例
#include <string> #include <iostream> int main() { using namespace std::string_literals; std::string s1 = "abc\0\0def"; std::string s2 = "abc\0\0def"s; std::cout << "s1: " << s1.size() << " \"" << s1 << "\"\n"; std::cout << "s2: " << s2.size() << " \"" << s2 << "\"\n"; }
出力例:
s1: 3 "abc" s2: 8 "abc^@^@def"