std::filesystem::path::c_str, std::filesystem::path::native, std::filesystem::path::operator string_type()
提供: cppreference.com
<tbody>
</tbody>
const value_type* c_str() const noexcept; |
(1) | (C++17以上) |
const string_type& native() const noexcept; |
(2) | (C++17以上) |
operator string_type() const; |
(3) | (C++17以上) |
文字列としてのネイティブパス名にアクセスします。
1)
native().c_str() と同等です。2) パス名のネイティブ形式の表現を参照で返します。
3) パス名のネイティブ形式の表現を値で返します。
引数
(なし)
戻り値
ネイティブな構文を使用し、ネイティブな文字型を使用し、ネイティブな文字エンコーディングを使用する、パス名のネイティブ文字列表現。 この文字列は OS の API で使用するのに適しています。
ノート
変換関数 (3) は、std::basic_string のファイル名を取る API でコードを変更せずにパス名を使用できるようにするために、提供されています。
例
Run this code
#include <cstdio>
#ifdef _MSC_VER
#include <io.h>
#include <fcntl.h>
#else
#include <locale>
#include <clocale>
#endif
#include <fstream>
#include <iostream>
#include <filesystem>
namespace fs = std::filesystem;
int main()
{
#ifdef _MSC_VER
_setmode(_fileno(stderr), _O_WTEXT);
#else
std::setlocale(LC_ALL, "");
std::locale::global(std::locale(""));
std::cout.imbue(std::locale());
std::wcerr.imbue(std::locale());
#endif
fs::path p = fs::u8path(u8"要らない.txt");
std::ofstream(p) << "File contents"; // LWG2676 の前では、 string_type が wstring
// である MSVC においては、 operator string_type()
// の使用は非標準の拡張によってのみ動作します。
// LWG2676 の後では、 fstream の新しいコンストラクタ
// が使用されます。
// ネイティブ文字列表現は OS の API で使用できます。
if (std::FILE* f =
#ifdef _MSC_VER
_wfopen(p.c_str(), L"r")
#else
std::fopen(p.c_str(), "r")
#endif
)
{
int ch;
while((ch=fgetc(f))!= EOF) putchar(ch);
std::fclose(f);
}
// マルチバイト表現とワイド表現は出力のために使用できます。
std::cout << "\nFile name in narrow multibyte encoding: " << p.string() << '\n';
std::wcerr << "File name in wide encoding: " << p.wstring() << '\n';
fs::remove(p);
}
出力:
File contents
File name in narrow multibyte encoding: 要らない.txt
File name in wide encoding: 要らない.txt
関連項目
| 文字列に変換されたネイティブパス名形式のパスを返します (パブリックメンバ関数) | |
| 文字列に変換された汎用パス名形式のパスを返します (パブリックメンバ関数) |