| 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] |