Library: Input/output
basic_ostream
basic_fstream
basic_iostream basic_ios
ios_base
basic_istream
|
basic_fstream() char_type close() |
fd() int_type is_open() |
off_type open() pos_type |
rdbuf() traits_type ~basic_fstream() |
Class that supports reading and writing of named files or devices associated with a file descriptor
#include <fstream>
namespace std {
template<class charT, class traits = char_traits<charT> >
class basic_fstream;
}
The class template basic_fstream supports reading and writing to named files or other devices associated with a file descriptor. It uses a basic_filebuf object to control the associated sequences. It inherits from basic_iostream and can therefore use all the formatted and unformatted input and output functions.
namespace std {
template<class charT, class traits = char_traits<charT> >
class basic_fstream
: public basic_iostream<charT, traits> {
public:
typedef charT char_type;
typedef traits traits_type;
typedef typename traits_type::int_type int_type;
typedef typename traits_type::pos_type pos_type;
typedef typename traits_type::off_type off_type;
basic_fstream();
explicit basic_fstream(const char*,
ios_base::openmode = ios_base::in | ios_base::out);
// extensions:
explicit basic_fstream(const char*,
ios_base::openmode,
long);
explicit basic_fstream(int, char_type* = 0,
streamsize = /* default size */);
explicit basic_fstream(FILE*, char_type* = 0,
streamsize = /* default size */);
virtual ~basic_fstream();
basic_filebuf<char_type, traits_type> *rdbuf() const;
bool is_open() const;
void open(const char*, ios_base::openmode = ios_base::in);
// extensions:
int fd() const;
void open(const char*, ios_base::openmode, long);
void open(int, char_type* = 0,
streamsize = /* default size */);
void open(FILE*, char_type* = 0,
streamsize = /* default size */);
void close();
};
}
char_type
The type char_type is a synonym for the template parameter charT.
int_type
The type int_type is a synonym of type traits_type::in_type.
off_type
The type off_type is a synonym of type traits_type::off_type.
pos_type
The type pos_type is a synonym of type traits_type::pos_type.
traits_type
The type traits_type is a synonym for the template parameter traits.
fstream
The type fstream is an instantiation of class basic_fstream on type char:
typedef basic_fstream<char> fstream;
wfstream
The type wfstream is an instantiation of class basic_fstream on type wchar_t:
typedef basic_fstream<wchar_t> wfstream;
basic_fstream();
Constructs an object of class basic_fstream, initializing the base class basic_iostream with the associated file buffer. This buffer is initialized by calling the basic_filebuf constructor:
basic_filebuf<char_type, traits_type>(rdbuf())
After construction, a file can be attached to the basic_fstream object by using the open() member function.
basic_fstream(const char* s,
ios_base::openmode mode =
ios_base::in | iosw_base::out);
Constructs an object of class basic_fstream, initializing the base class basic_iostream with the associated file buffer. This buffer is initialized by calling the constructor:
basic_filebuf<char_type, traits_type>(rdbuf())
The constructor then calls open(s, mode) in order to attach the file, whose name is pointed to by s, to the basic_fstream object.
basic_fstream(const char* s, ios_base::openmode mode,
long protection);
Constructs an object of class basic_fstream, initializing the base class basic_iostream with the associated file buffer. This buffer is initialized by calling the basic_filebuf constructor:
basic_filebuf<char_type, traits_type>(rdbuf())
The constructor then calls:
rdbuf()->open(s, mode, protection)
in order to attach the file, whose name is pointed to by s, to the basic_fstream object.
The third argument, protection, holds file permissions. It determines the file read/write/execute permissions under UNIX, but is more limited elsewhere.
NOTE -- The protection argument is not part of the C++ Standard, but is included here as a convenience extension. See Appendix B for a complete list of extensions of this implementation.
basic_fstream(int fd, char_type *buf, streamsize n);
Constructs an object of class basic_fstream, initializing the base class basic_iostream with the associated file buffer. This buffer is initialized by calling the basic_filebuf constructor:
basic_filebuf<char_type, traits_type>(rdbuf ())
The constructor then calls:
rdbuf()->open (fd, buf, n)
in order to attach the file descriptor fd to the basic_fstream object. If the function fails, it sets ios_base::failbit.
NOTE -- This function is not part of the C++ Standard, but is included here as an extension in order to manipulate pipes, sockets, or other UNIX devices that can be accessed through file descriptors. See Appendix B for a complete list of extensions of this implementation.
basic_fstream(FILE *fp, char_type* buf, streamsize n);
Constructs an object of class basic_fstream, initializing the base class basic_iostream with the associated file buffer. This buffer is initialized by calling the basic_filebuf constructor:
basic_filebuf<char_type, traits_type>(rdbuf ())
The constructor then calls:
rdbuf()->open (fp, buf, n)
in order to attach the file pointer fp to the basic_fstream object. If the function fails, it sets ios_base::failbit.
NOTE -- This function is not part of the C++ Standard, but is provided here as a convenience extension. See Appendix B for a complete list of extensions of this implementation.
virtual ~basic_fstream();
Destroys an object of class basic_fstream.
void close();
Calls rdbuf()->close(). If this function fails, it calls setstate(failbit).
int fd() const;
Returns the file descriptor associated with the stream.
NOTE -- This function is not part of the C++ Standard, but is provided here as a convenience extension. See Appendix B for a complete list of extensions of this implementation.
bool is_open() const;
Returns rdbuf()->is_open().
void
open(const char* s,
ios_base::openmode = ios_base::in | ios_base::out);
Calls rdbuf()->open(s, mode). If this function fails to open the file, it calls the basic_ios member function setstate(failbit).
void
open(const char* s,
ios_base::openmode, long protection);
Calls rdbuf()->open (s, mode, protection). If this function fails to open the file, it calls setstate(failbit).
The third argument, protection, holds file permissions. It determines the file read/write/execute permissions under UNIX. It is more limited under DOS, since files are always readable and do not have special execute permission.
NOTE -- The protection argument does not appear in the C++ Standard C++, but is included here as a convenience extension. See Appendix B for a complete list of extensions of this implementation.
void
open(int fd, char_type *buf = 0,
streamsize n = /* default size */);
Calls rdbuf()->open (fd, buf, n). If this function fails to open the file, it calls setstate(failbit).
NOTE -- This function is not part of the C++ Standard, but is provided here as a convenience extension. See Appendix B for a complete list of extensions of this implementation.
void
open(FILE *fp, char_type *buf = 0,
streamsize n = /* default size */);
Returns open(fileno (fp), buf, n). If this function fails to open the file, it calls setstate(failbit).
fileno is a UNIX98 function declared in <cstdio>.
NOTE -- This function is not part of the C++ Standard, but is provided here as a convenience extension. See Appendix B for a complete list of extensions of this implementation.
basic_filebuf<charT_type,traits_type>* rdbuf() const;
Returns a pointer to the basic_filebuf associated with the stream.
//
// fstream.cpp
//
#include <fstream> // for fstream
#include <iostream> // for cout, endl
#include <string> // for string
int main ( )
{
// create a bi-directional fstream object
std::fstream inout ("test_fstream.out",
std::ios::in | std::ios::out |
std::ios::trunc);
// write out three lines to the file
inout << "Dieses ist die Geschichte eines Mannes.\n"
<< "C'est l'histoire d'un homme.\n"
<< "This is the story of a man." << std::endl;
std::string line;
// seek back to the beginning of the file
inout.seekg (0);
// extract the first line
std::getline (inout, line);
// output the first line to standard output
std::cout << "\nDeutsch:\n" << line << std::endl;
// obtain current position in file
std::fstream::pos_type pos = inout.tellg ();
// extract the second line
std::getline (inout, line);
// output the second line to standard output
std::cout << "Français:\n" << line << std::endl;
// extract the third line
std::getline (inout, line);
// output the third line to standard output
std::cout << "English:\n" << line << std::endl;
// move the put sequence before the second line
inout.seekp (pos);
// replace the second and third lines
inout << "This is the story of a man.\n"
<< "C'est l'histoire d'un homme.";
// seek to the beginning of the file
inout.seekg (0);
// output the all content of the fstream object to stdout
std::cout << "\n" << inout.rdbuf () << std::endl;
return 0;
}
Program Output:
Deutsch: Dieses ist die Geschichte eines Mannes. Francais: C'est l'histoire d'un homme. English: This is the story of a man. Dieses ist die Geschichte eines Mannes. This is the story of a man. C'est l'histoire d'un homme.
char_traits, ios_base, basic_ios, basic_filebuf, basic_ifstream, basic_ofstream
ISO/IEC 14882:1998 -- International Standard for Information Systems --Programming Language C++, Section 27.8.1.11