std::experimental::filesystem::path:: c_str, std::experimental::filesystem::path:: native, std::experimental::filesystem::path:: operator string_type()
From cppreference.net
<
cpp
|
experimental
|
fs
|
path
|
const
value_type
*
c_str
(
)
const
;
|
(1) | (filesystem TS) |
|
const
string_type
&
native
(
)
const
;
|
(2) | (filesystem TS) |
|
operator string_type
(
)
const
;
|
(3) | (filesystem TS) |
Обращается к собственному имени пути как к строке символов.
1)
Эквивалентно
native
(
)
.
c_str
(
)
.
2)
Возвращает нативное строковое представление пути по ссылке.
3)
Возвращает нативное строковое представление пути по значению.
Содержание |
Параметры
(нет)
Возвращаемое значение
Нативное строковое представление пути, использующее нативный синтаксис, нативный тип символов и нативную кодировку символов. Эта строка подходит для использования с API операционной системы.
Исключения
1,2)
noexcept
спецификация:
noexcept
Примечания
Функция преобразования (3) предоставляется для того, чтобы стандартные API открытия файлов, принимающие std::basic_string в качестве имён файлов, такие как конструктор std::ifstream , могли использовать пути без изменений в коде:
fs::path p = "/tmp/text.txt"; std::ifstream f(p);
Пример
Запустить этот код
#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
Смотрите также
|
возвращает путь в формате нативного имени пути, преобразованный в строку
(public member function) |
|
|
возвращает путь в формате общего имени пути, преобразованный в строку
(public member function) |