std::experimental::filesystem::path:: string,wstring,u8string,...
|
template
<
class
CharT,
class
Traits
=
std::
char_traits
<
CharT
>
,
class
Alloc
=
std::
allocator
<
CharT
>
>
|
(1) | (filesystem TS) |
| (2) | (filesystem TS) | |
|
std::
string
string
(
)
const
;
|
||
|
std::
wstring
wstring
(
)
const
;
|
||
|
std::
string
u8string
(
)
const
;
|
||
|
std::
u16string
u16string
(
)
const
;
|
||
|
std::
u32string
u32string
(
)
const
;
|
||
Возвращает внутреннее имя пути в формате родного имени пути, преобразованное в конкретный строковый тип. Преобразование, если оно есть, указано в todo .
u8string()
всегда является UTF-8.
Содержание |
Параметры
(нет)
Возвращаемое значение
Внутреннее имя пути в формате собственного имени пути, преобразованное в указанный строковый тип.
Исключения
Может генерировать исключения, определяемые реализацией.
Пример
#include <clocale> #include <cstdio> #include <experimental/filesystem> #include <fstream> #include <iostream> namespace fs = std::experimental::filesystem; int main() { std::setlocale(LC_ALL, "en_US.utf8"); std::locale::global(std::locale("en_US.utf8")); fs::path p = fs::u8path(u8"要らない.txt"); // native string representation can be used with OS APIs std::ofstream(p) << "File contents"; // this uses operator string() if (std::FILE* f = std::fopen(p.c_str(), "r")) { int ch; while ((ch=fgetc(f))!= EOF) putchar(ch); std::fclose(f); } // multibyte and wide representation can be used for output std::cout.imbue(std::locale()); std::cout << "\nFile name in narrow multibyte encoding: " << p.string() << '\n'; std::wcerr.imbue(std::locale()); 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
Смотрите также
|
возвращает путь в формате общего имени пути, преобразованный в строку
(публичная функция-член) |