std::basic_fstream<CharT,Traits>::is_open
From cppreference.com
< cpp | io | basic fstream
C++
Input/output library
| 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) |
std::basic_fstream
| 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 calls rdbuf()->is_open().
Contents |
[edit] Parameters
(none)
[edit] Return value
true if the file stream has an associated file, false otherwise.
[edit] Example
Run this code
#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() = false fs.is_open() = true
[edit] Defect reports
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 with const qualifier
|
declared with const qualifier |
[edit] See also
| opens a file and associates it with the stream (public member function) [edit] | |
| closes the associated file (public member function) [edit] |