I/O manipulators | ||||
Print functions(C++23) | ||||
C-style I/O | ||||
Buffers | ||||
(C++23) | ||||
(C++98/26*) | ||||
(C++20) | ||||
Streams | ||||
Abstractions | ||||
File I/O | ||||
String I/O | ||||
Array I/O | ||||
(C++23) | ||||
(C++23) | ||||
(C++23) | ||||
(C++98/26*) | ||||
(C++98/26*) | ||||
(C++98/26*) | ||||
Synchronized Output | ||||
(C++20) | ||||
Types | ||||
Error category interface | ||||
(C++11) | ||||
(C++11) |
Member functions | ||||
(C++11) | ||||
(C++11) | ||||
(C++26) | ||||
File operations | ||||
basic_fstream::is_open | ||||
Non-member functions | ||||
(C++11) |
bool is_open()const; | ||
Checks if the file stream has an associated file.
Effectively callsrdbuf()->is_open().
Contents |
(none)
true if the file stream has an associated file,false otherwise.
#include <fstream>#include <iostream>#include <string> int main(){std::string filename="some_file"; std::fstream fs(filename, std::ios::in); std::cout<<std::boolalpha;std::cout<<"fs.is_open() = "<< fs.is_open()<<'\n'; if(!fs.is_open()){ fs.clear(); fs.open(filename, std::ios::out);std::cout<<"fs.is_open() = "<< fs.is_open()<<'\n';}}
Possible output:
fs.is_open() = falsefs.is_open() = true
The following behavior-changing defect reports were applied retroactively to previously published C++ standards.
DR | Applied to | Behavior as published | Correct behavior |
---|---|---|---|
LWG 365 | C++98 | is_open was not declared withconst qualifier | declared withconst qualifier |
opens a file and associates it with the stream (public member function)[edit] | |
closes the associated file (public member function)[edit] |