Nota
O acesso a esta página requer autorização. Podes tentar iniciar sessão ou mudar de diretório.
O acesso a esta página requer autorização. Podes tentar mudar de diretório.
Descreve um objeto que controla a inserção e extração de elementos e objetos codificados usando um buffer de fluxo de classe basic_filebuf<Elem, Tr>, com elementos do tipo Elem, cujos traços de caractere são determinados pela classe Tr.
Sintaxe
template <class Elem, class Tr = char_traits<Elem>>
class basic_fstream : public basic_iostream<Elem, Tr>
Parâmetros
Elem
O elemento básico do buffer de arquivos.
Tr
As características do elemento básico do buffer de arquivos (geralmente char_traits<Elem>).
Observações
O objeto armazena um objeto de classe basic_filebuf<Elem, . Tr>
Observação
O ponteiro get e o ponteiro put de um objeto fstream NÃO são independentes um do outro. Se o ponteiro get se move, o ponteiro put também se move.
Exemplo
O exemplo a seguir demonstra como criar um basic_fstream objeto que pode ser lido e gravado.
// basic_fstream_class.cpp
// compile with: /EHsc
#include <fstream>
#include <iostream>
using namespace std;
int main(int argc, char **argv)
{
fstream fs("fstream.txt", ios::in | ios::out | ios::trunc);
if (!fs.bad())
{
// Write to the file.
fs << "Writing to a basic_fstream object..." << endl;
fs.close();
// Dump the contents of the file to cout.
fs.open("fstream.txt", ios::in);
cout << fs.rdbuf();
fs.close();
}
}
Writing to a basic_fstream object...
Construtores
| Construtor | Descrição |
|---|---|
| basic_fstream | Constrói um objeto do tipo basic_fstream. |
Funções de membro
| Função de membro | Descrição |
|---|---|
| fechar | Fecha um arquivo. |
| is_open | Determina se um arquivo está aberto. |
| abrir | Abre um arquivo. |
| RDBUF | Retorna o endereço do buffer de fluxo armazenado, do tipo ponteiro para basic_filebuf<Elem, Tr>. |
| trocar | Troca o conteúdo deste objeto com o conteúdo de outro basic_fstream objeto. |
Requerimentos
Cabeçalho:<fstream>
Espaço de nomes: std
basic_fstream::basic_fstream
Constrói um objeto do tipo basic_fstream.
basic_fstream();
explicit basic_fstream(
const char* _Filename,
ios_base::openmode _Mode = ios_base::in | ios_base::out,
int _Prot = (int)ios_base::_Openprot);
explicit basic_fstream(
const wchar_t* _Filename,
ios_base::openmode _Mode = ios_base::in | ios_base::out,
int _Prot = (int)ios_base::_Openprot);
basic_fstream(basic_fstream&& right);
Parâmetros
_Filename
O nome do arquivo a ser aberto.
_Mode
Uma das enumerações em ios_base::openmode.
_Prot
A proteção de abertura de arquivo padrão, equivalente ao parâmetro shflag no _fsopen, _wfsopen.
Observações
O primeiro construtor inicializa a classe base chamando basic_iostream(sb), onde sb é o objeto armazenado da classe basic_filebuf<Elem, Tr>. Ele também inicializa sb chamando basic_filebuf<Elem, Tr>.
O segundo e terceiro construtores inicializa a classe base chamando basic_iostream( sb). Ele também inicializa sb chamando basic_filebuf<Elem, Tr> e, em seguida, sb.open(_ Nome do arquivo, _Mode). Se a última função retorna um ponteiro nulo, o construtor chama setstate(failbit).
O quarto construtor inicializa o objeto com o conteúdo de , tratado como uma referência rvalue right.
Exemplo
Consulte streampos para obter um exemplo que usa basic_fstreamo .
basic_fstream::fechar
Fecha um arquivo.
void close();
Observações
A função de membro chama rdbuf-close>.
Exemplo
Consulte basic_filebuf::close para obter um exemplo de como usar closeo .
basic_fstream::is_open
Determina se um arquivo está aberto.
bool is_open() const;
Valor de retorno
true se o arquivo estiver aberto, false caso contrário.
Observações
A função de membro retorna rdbuf-is_open>.
Exemplo
Consulte basic_filebuf::is_open para obter um exemplo de como usar is_openo .
basic_fstream::aberto
Abre um arquivo.
void open(
const char* _Filename,
ios_base::openmode _Mode = ios_base::in | ios_base::out,
int _Prot = (int)ios_base::_Openprot);
void open(
const char* _Filename,
ios_base::openmode _Mode);
void open(
const wchar_t* _Filename,
ios_base::openmode _Mode = ios_base::in | ios_base::out,
int _Prot = (int)ios_base::_Openprot);
void open(
const wchar_t* _Filename,
ios_base::openmode _Mode);
Parâmetros
_Filename
O nome do arquivo a ser aberto.
_Mode
Uma das enumerações em ios_base::openmode.
_Prot
A proteção de abertura de arquivo padrão, equivalente ao parâmetro shflag no _fsopen, _wfsopen.
Observações
A função de membro chama rdbuf-open>(_ Nome do arquivo, _Mode). Se essa função retornar um ponteiro nulo, a função chamará setstate(failbit).
Exemplo
Consulte basic_filebuf::open para obter um exemplo de como usar openo .
basic_fstream::operador=
Atribui a este objeto o conteúdo de um objeto de fluxo especificado. Esta é uma atribuição de movimento que envolve um valor de rvalue que não deixa uma cópia para trás.
basic_fstream& operator=(basic_fstream&& right);
Parâmetros
direito
Uma referência lvalue a um basic_fstream objeto.
Valor de retorno
Retorna *this.
Observações
O operador membro substitui o conteúdo do objeto usando o conteúdo do direito, tratado como uma referência de rvalue.
basic_fstream::rdbuf
Retorna o endereço do buffer de fluxo armazenado, do tipo ponteiro para basic_filebuf<Elem, Tr>.
basic_filebuf<Elem, Tr> *rdbuf() const
Valor de retorno
O endereço do buffer de fluxo armazenado.
Exemplo
Consulte basic_filebuf::close para obter um exemplo de como usar rdbufo .
basic_fstream::swap
Troca o conteúdo de dois basic_fstream objetos.
void swap(basic_fstream& right);
Parâmetros
direito
Uma lvalue referência a um basic_fstream objeto.
Observações
A função de membro troca o conteúdo deste objeto e o conteúdo do direito.
Ver também
segurança de threads na biblioteca padrão C++
Programação iostream
iostreams Convenções