Observação
O acesso a essa página exige autorização. Você pode tentar entrar ou alterar diretórios.
O acesso a essa página exige autorização. Você pode tentar alterar os diretórios.
Classe
A classe path armazena um objeto do tipo string_type, chamado myname aqui para fins de explicação, adequada para uso como um nome de caminho. string_type é um sinônimo para basic_string<value_type>, em que value_type é um sinônimo para wchar_t no Windows ou char em POSIX.
Para obter mais informações e exemplos de código, consulte Navegação do Sistema de Arquivos (C++).
Sintaxe
class path;
Construtores
| Construtor | Descrição |
|---|---|
path |
Constrói um path. |
Typedefs
| Nome do tipo | Descrição |
|---|---|
const_iterator |
Um sinônimo de iterator. |
iterator |
Um iterador de constante bidirecional que designa os componentes path de myname. |
string_type |
O tipo é um sinônimo de basic_string<value_type>. |
Funções de membro
| Função de membro | Descrição |
|---|---|
append |
Acrescenta a sequência especificada a mypath, convertida e inserindo um preferred_separator conforme necessário. |
assign |
Substitui mypath com a sequência especificada, convertida conforme necessário. |
begin |
Retorna um path::iterator designando o primeiro elemento de caminho no nome do caminho, se existir. |
c_str |
Retorna um ponteiro para o primeiro caractere em mypath. |
clear |
Executa mypath.clear(). |
compare |
Retorna valores de comparação. |
concat |
Acrescenta a sequência especificada a mypath, convertida (mas não inserindo um separador) conforme necessário. |
empty |
Retorna mypath.empty(). |
end |
Retorna um iterador de fim de sequência do tipo iterator. |
extension |
Retorna o sufixo de filename(). |
filename |
Retorna o componente do diretório raiz de myname, especificamente empty() ? path() : *--end(). O componente pode estar vazio. |
generic_string |
Retorna this->string<Elem, Traits, Alloc>(al) com (em Windows) qualquer barra invertida convertida em barra "/". |
generic_u16string |
Retorna u16string() com (em Windows) qualquer barra invertida convertida em barra "/". |
generic_u32string |
Retorna u32string() com (em Windows) qualquer barra invertida convertida em barra "/". |
generic_u8string |
Retorna u8string() com (em Windows) qualquer barra invertida convertida em barra "/". |
generic_wstring |
Retorna wstring() com (em Windows) qualquer barra invertida convertida em barra "/". |
has_extension |
Retorna !extension().empty(). |
has_filename |
Retorna !filename().empty(). |
has_parent_path |
Retorna !parent_path().empty(). |
has_relative_path |
Retorna !relative_path().empty(). |
has_root_directory |
Retorna !root_directory().empty(). |
has_root_name |
Retorna !root_name().empty(). |
has_root_path |
Retorna !root_path().empty(). |
has_stem |
Retorna !stem().empty(). |
is_absolute |
Para o Windows, a função retorna has_root_name() && has_root_directory(). Para o POSIX, a função retorna has_root_directory(). |
is_relative |
Retorna !is_absolute(). |
make_preferred |
Converte cada separador em um preferred_separator, conforme necessário. |
native |
Retorna a representação nativa do caminho. |
parent_path |
Retorna o componente de caminho pai de myname. |
preferred_separator |
O objeto constante fornece o caractere preferencial para separar os componentes do caminho, dependendo do sistema operacional do host. |
relative_path |
Retorna o componente de caminho relativo de myname. |
remove_filename |
Remove o nome do arquivo. |
replace_extension |
Substitui a extensão de myname. |
replace_filename |
Substitui o nome do arquivo. |
root_directory |
Retorna o componente do diretório raiz de myname. |
root_name |
Retorna o componente de nome raiz de myname. |
root_path |
Retorna o componente de caminho raiz de myname. |
stem |
Retorna o componente stem de myname. |
string |
Converte a sequência armazenada em mypath. |
swap |
Executa swap(mypath, right.mypath). |
u16string |
Converte a sequência armazenada em mypath em UTF-16 e a retorna armazenada em um objeto do tipo u16string. |
u32string |
Converte a sequência armazenada em mypath em UTF-32 e a retorna armazenada em um objeto do tipo u32string. |
u8string |
Converte a sequência armazenada em mypath em UTF-8 e a retorna armazenada em um objeto do tipo u8string. |
value_type |
O tipo descreve os elementos de caminho preferidos pelo sistema operacional do host. |
wstring |
Converte a sequência armazenada em mypath na codificação preferida pelo sistema de host para uma sequência wchar_t e a retorna armazenada em um objeto do tipo wstring. |
Operadores
| Operador | Descrição |
|---|---|
operator= |
Substitui os elementos do caminho por uma cópia de outro caminho. |
operator+= |
Diversas expressões concat. |
operator/= |
Diversas expressões append. |
operator string_type |
Retorna myname. |
Requisitos
Cabeçalho: <filesystem>
Namespace: std::experimental::filesystem
path::append
Acrescenta a sequência especificada a mypath, convertida e inserindo um preferred_separator conforme necessário.
template <class Source>
path& append(const Source& source);
template <class InIt>
path& append(InIt first, InIt last);
Parâmetros
source
A sequência especificada.
first
O início da sequência especificada.
last
O fim da sequência especificada.
path::assign
Substitui mypath com a sequência especificada, convertida conforme necessário.
template <class Source>
path& assign(const Source& source);
template <class InIt>
path& assign(InIt first, InIt last);
Parâmetros
source
A sequência especificada.
first
O início da sequência especificada.
last
O fim da sequência especificada.
path::begin
Retorna um path::iterator designando o primeiro elemento de caminho no nome do caminho, se existir.
iterator begin() const;
path::c_str
Retorna um ponteiro para o primeiro caractere em mypath.
const value_type& *c_str() const noexcept;
path::clear
Executa mypath.clear().
void clear() noexcept;
path::compare
A primeira função retorna mypath.compare(pval.native()). A segunda função retorna mypath.compare(str). A terceira função retorna mypath.compare(ptr).
int compare(const path& pval) const noexcept;
int compare(const string_type& str) const;
int compare(const value_type *ptr) const;
Parâmetros
pval
O caminho a ser comparado.
str
A cadeia de caracteres a ser comparada.
ptr
O ponteiro a ser comparado.
path::concat
Acrescenta a sequência especificada a mypath, convertida (mas não inserindo um separador) conforme necessário.
template <class Source>
path& concat(const Source& source);
template <class InIt>
path& concat(InIt first, InIt last);
Parâmetros
source
A sequência especificada.
first
O início da sequência especificada.
last
O fim da sequência especificada.
path::const_iterator
Um sinônimo de iterator.
typedef iterator const_iterator;
path::empty
Retorna mypath.empty().
bool empty() const noexcept;
path::end
Retorna um iterador de fim de sequência do tipo iterator.
iterator end() const;
path::extension
Retorna o sufixo de filename().
path extension() const;
Comentários
Retorna o sufixo de filename() X, de modo que:
Se X == path(".") || X == path("..") ou se X não contiver nenhum ponto, o sufixo será vazio.
Caso contrário, o sufixo começa com (e inclui) o ponto mais à direita.
path::filename
Retorna o componente do diretório raiz de myname, especificamente empty() path() : *--end(). O componente pode estar vazio.
path filename() const;
path::generic_string
Retorna this->string<Elem, Traits, Alloc>(al) com (em Windows) qualquer barra invertida convertida em barra "/".
template <class Elem,
class Traits = char_traits<Elem>,
class Alloc = allocator<Elem>>
basic_string<Elem, Traits, Alloc>
generic_string(const Alloc& al = Alloc()) const;
string generic_string() const;
path::generic_u16string
Retorna u16string() com (em Windows) qualquer barra invertida convertida em barra "/".
u16string generic_u16string() const;
path::generic_u32string
Retorna u32string() com (em Windows) qualquer barra invertida convertida em barra "/".
u32string generic_u32string() const;
path::generic_u8string
Retorna u8string() com (em Windows) qualquer barra invertida convertida em barra "/".
string generic_u8string() const;
path::generic_wstring
Retorna wstring() com (em Windows) qualquer barra invertida convertida em barra "/".
wstring generic_wstring() const;
path::has_extension
Retorna !extension().empty().
bool has_extension() const;
path::has_filename
Retorna !filename().empty().
bool has_filename() const;
path::has_parent_path
Retorna !parent_path().empty().
bool has_parent_path() const;
path::has_relative_path
Retorna !relative_path().empty().
bool has_relative_path() const;
path::has_root_directory
Retorna !root_directory().empty().
bool has_root_directory() const;
path::has_root_name
Retorna !root_name().empty().
bool has_root_name() const;
path::has_root_path
Retorna !root_path().empty().
bool has_root_path() const;
path::has_stem
Retorna !stem().empty().
bool has_stem() const;
path::is_absolute
Para o Windows, a função retorna has_root_name() && has_root_directory(). Para o POSIX, a função retorna has_root_directory().
bool is_absolute() const;
path::is_relative
Retorna !is_absolute().
bool is_relative() const;
path::iterator
Um iterador de constante bidirecional que designa os componentes path de myname.
class iterator
{
// bidirectional iterator for path
typedef bidirectional_iterator_tag iterator_category;
typedef path_type value_type;
typedef ptrdiff_t difference_type;
typedef const value_type *pointer;
typedef const value_type& reference;
// ...
};
Comentários
A classe descreve um iterador bidirecional constante que designa os componentes path de myname na sequência:
o nome raiz, se existir
o diretório raiz, se existir
os elementos de diretório restantes do
pathpai, se existirem, terminando com o nome do arquivo, se existir
Para pval, um objeto do tipo path:
path::iterator X = pval.begin()designa o primeiro elementopathno nome do caminho, se existir.X == pval.end()étruequandoXaponta para logo após o final da sequência de componentes.*Xretorna uma cadeia de caracteres que corresponde ao componente atual++Xdesigna o próximo componente na sequência, se existir.--Xdesigna o componente anterior na sequência, se existir.Alterar
mynameinvalida todos os iteradores que designam elementos emmyname.
path::make_preferred
Converte cada separador em um preferred_separator, conforme necessário.
path& make_preferred();
path::native
Obtenha a representação de cadeia de caracteres nativa do caminho.
const string_type& native() const noexcept;
Comentários
O caminho está disponível em um formato genérico portátil (consulte generic_string()) ou no formato nativo do caminho. Essa função retorna a cadeia de caracteres nativa. Em um sistema POSIX, o formato genérico e o formato nativo são os mesmos.
No exemplo a seguir em execução no Windows 11, a cadeia de caracteres de caminho genérico é c:/t/temp/temp.txt e a cadeia de caracteres nativa é c:\\t\\temp.txt
// Compile with /std:c++17 or higher
#include <filesystem>
int main()
{
std::filesystem::path p(R"(c:\t\temp.txt)");
auto native = p.native(); // Windows: L"c:\\t\temp.txt"
auto generic = p.generic_string(); // Windows: "c:/t/temp.txt"
}
path::operator=
Substitui os elementos do caminho por uma cópia de outro caminho.
path& operator=(const path& right);
path& operator=(path&& right) noexcept;
template <class Source>
path& operator=(const Source& source);
Parâmetros
right
O path que está sendo copiado no path.
source
A fonte de path.
Comentários
O primeiro operador membro copia right.myname para myname. O segundo operador membro move right.myname para myname. O terceiro operador membro se comporta da mesma maneira que *this = path(source).
path::operator+=
Diversas expressões concat.
path& operator+=(const path& right);
path& operator+=(const string_type& str);
path& operator+=(const value_type *ptr);
path& operator+=(value_type elem);
template <class Source>
path& operator+=(const Source& source);
template <class Elem>
path& operator+=(Elem elem);
Parâmetros
right
O caminho adicionado.
str
A cadeia de caracteres adicionada.
ptr
O ponteiro adicionado.
elem
O value_type ou Elem adicionado.
source
A fonte adicionada.
Comentários
As funções de membro se comportam da mesma maneira que as seguintes expressões correspondentes:
concat(right);concat(path(str));concat(ptr);concat(string_type(1, elem));concat(source);concat(path(basic_string<Elem>(1, elem)));
path::operator/=
Diversas expressões append.
path& operator/=(const path& right);
template <class Source>
path& operator/=(const Source& source);
Parâmetros
right
O caminho adicionado.
source
A fonte adicionada.
Comentários
As funções de membro se comportam da mesma maneira que as seguintes expressões correspondentes:
append(right);append(source);
path::operator string_type
Retorna myname.
operator string_type() const;
path::parent_path
Retorna o componente de caminho pai de myname.
path parent_path() const;
Comentários
Retorna o componente de caminho pai de myname, especificamente o prefixo de myname após a remoção de filename().native() e qualquer separador de diretório imediatamente anterior. (Da mesma forma, se begin() != end(), é a combinação de todos os elementos no intervalo [begin(), --end()) aplicando operator/= sucessivamente.) O componente pode estar vazio.
path::path
Constrói um de path várias maneiras.
path();
path(const path& right);
path(path&& right) noexcept;
template <class Source>
path(const Source& source);
template <class Source>
path(const Source& source, const locale& loc);
template <class InIt>
path(InIt first, InIt last);
template <class InIt>
path(InIt first, InIt last, const locale& loc);
Parâmetros
right
O caminho do qual o caminho construído deve ser uma cópia.
source
A origem da qual o caminho construído deve ser uma cópia.
loc
A localidade especificada.
first
A posição do primeiro elemento a ser copiado.
last
A posição do último elemento a ser copiado.
Comentários
Todos os construtores criam myname de várias maneiras:
Para path(), é myname().
Para path(const path& right, é myname(right.myname).
Para path(path&& right), é myname(right.myname).
Para template<class Source> path(const Source& source), é myname(source).
Para template<class Source> path(const Source& source, const locale& loc) ele é myname(source), obtendo todas as facetas codecvt necessárias de loc.
Para template<class InIt> path(InIt first, InIt last), é myname(first, last).
Para template<class InIt> path(InIt first, InIt last, const locale& loc) ele é myname(first, last), obtendo todas as facetas codecvt necessárias de loc.
path::preferred_separator
O objeto constante fornece o caractere preferencial para separar os componentes do caminho, dependendo do sistema operacional do host.
#if _WIN32_C_LIB
static constexpr value_type preferred_separator == L'\\';
#else // assume POSIX
static constexpr value_type preferred_separator == '/';
#endif // filesystem model now defined
Comentários
Usar L'/' em lugar dele é igualmente permitido na maioria dos contextos no Windows.
path::relative_path
Retorna o componente de caminho relativo de myname.
path relative_path() const;
Comentários
Retorna o componente de caminho relativo de myname, especificamente o sufixo de myname após remover root_path().native() e os separadores de diretório imediatamente subsequentes, se houver. O componente pode estar vazio.
path::remove_filename
Remove o nome do arquivo.
path& remove_filename();
path::replace_extension
Substitui a extensão de myname.
path& replace_extension(const path& newext = path());
Parâmetros
newext
A nova extensão.
Comentários
Primeiro, remove o sufixo extension().native() de myname. Depois, se !newext.empty() && newext[0] != dot (em que dot é *path(".").c_str()), então dot é acrescentado a myname. Em seguida, newext é acrescentado a myname.
path::replace_filename
Substitui o nome do arquivo.
path& replace_filename(const path& pval);
Parâmetros
pval
O caminho do nome do arquivo.
Comentários
A função membro executa:
remove_filename();
*this /= pval;
return (*this);
path::root_directory
Retorna o componente do diretório raiz de myname.
path root_directory() const;
Comentários
O componente pode estar vazio.
path::root_name
Retorna o componente de nome raiz de myname.
path root_name() const;
Comentários
O componente pode estar vazio.
path::root_path
Retorna o componente de caminho raiz de myname.
path root_path() const;
Comentários
Retorna o componente de caminho raiz de myname, especificamente root_name() / root_directory. O componente pode estar vazio.
path::stem
Retorna o componente stem de myname.
path stem() const;
Comentários
Retorna o componente stem de myname, especificamente filename().native(), removendo eventuais ocorrências de extension().native() à direita. O componente pode estar vazio.
path::string
Converte a sequência armazenada em mypath.
template \<class Elem, class Traits = char_traits\<Elem>, class Alloc = allocator\<Elem>>
basic_string\<Elem, Traits, Alloc> string(const Alloc& al = Alloc()) const;
string string() const;
Comentários
A primeira função membro (modelo) converte a sequência armazenada em mypath da mesma maneira que:
string()parastring<char, Traits, Alloc>()wstring()parastring<wchar_t, Traits, Alloc>()u16string()parastring<char16_t, Traits, Alloc>()u32string()parastring<char32_t, Traits, Alloc>()
A segunda função membro converte a sequência armazenada em mypath na codificação preferida pelo sistema de host para uma sequência char armazenada em um objeto do tipo string.
path::string_type
O tipo é um sinônimo de basic_string<value_type>.
typedef basic_string<value_type> string_type;
path::swap
Executa swap(mypath, right.mypath).
void swap(path& right) noexcept;
path::u16string
Converte a sequência armazenada em mypath em UTF-16 e a retorna armazenada em um objeto do tipo u16string.
u16string u16string() const;
path::u32string
Converte a sequência armazenada em mypath em UTF-32 e a retorna armazenada em um objeto do tipo u32string.
u32string u32string() const;
path::u8string
Converte a sequência armazenada em mypath em UTF-8 e a retorna armazenada em um objeto do tipo u8string.
string u8string() const;
path::value_type
O tipo descreve os elementos path preferidos pelo sistema operacional do host.
#if _WIN32_C_LIB
typedef wchar_t value_type;
#else // assume POSIX
typedef char value_type;
#endif // filesystem model now defined
path::wstring
Converte a sequência armazenada em mypath na codificação preferida pelo sistema de host para uma sequência wchar_t e a retorna armazenada em um objeto do tipo wstring.
wstring wstring() const;