template <class EcharT,
class traits = std::char_traits<EcharT>,
class Allocator = std::allocator<EcharT>>
std::basic_string<EcharT, traits, Allocator>
string(const Allocator& a = Allocator()) const; // (1)
std::string string() const; // (2)
概要
- (1) : 指定された文字型に対応する文字コードで、パス文字列を取得する
- (2) : システムのマルチバイト文字コードで、パス文字列を取得する
戻り値
*this
が保持するシステムのネイティブフォーマットを持つパスを、指定された文字型の文字コードで返す。
(1) の場合、戻り値の文字列をメモリアロケートするために、パラメータa
のアロケータを使用する。
備考
- (1) :
ECharT
がchar
の場合、システムのマルチバイト文字コードとなる (POSIXベースシステムではUTF-8、Windowsの日本語環境ではCP932)ECharT
がwchar_t
の場合、システムのワイド文字コードとなる (WindowsではUTF-16)ECharT
がchar8_t
の場合、UTF-8エンコーディングとなるECharT
がchar16_t
の場合、UTF-16エンコーディングとなるECharT
がchar32_t
の場合、UTF-32エンコーディングとなる
- (2) :
- POSIXベースシステムではUTF-8、Windowsの日本語環境ではCP932文字コードとなる
例
POSIXベースシステムでの例
#include <iostream>
#include <filesystem>
namespace fs = std::filesystem;
int main()
{
fs::path p = "/usr/bin/clang";
// (1)
{
const std::string s = p.string<char>();
const std::wstring ws = p.string<wchar_t>();
const std::u16string utf16s = p.string<char16_t>();
const std::u32string utf32s = p.string<char32_t>();
std::cout << s << std::endl;
}
// (2)
{
const std::string s = p.string();
std::cout << s << std::endl;
}
}
出力
/usr/bin/clang
/usr/bin/clang
Windowsでの例
#include <iostream>
#include <filesystem>
namespace fs = std::filesystem;
int main()
{
fs::path p = "foo/bar";
// (1)
{
const std::string s = p.string<char>();
const std::wstring ws = p.string<wchar_t>();
const std::u16string utf16s = p.string<char16_t>();
const std::u32string utf32s = p.string<char32_t>();
std::cout << s << std::endl;
}
// (2)
{
const std::string s = p.string();
std::cout << s << std::endl;
}
}
出力
foo/bar
foo/bar
バージョン
言語
- C++17
処理系
- Clang:
- GCC: 8.1 ✅
- Visual C++: 2017 Update 7 ✅