std::basic_ifstream<CharT,Traits>::is_open
From cppreference.com
< cpp | io | basic ifstream
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_ifstream
| Member functions | ||||
(C++11) | ||||
(C++11) | ||||
| File operations | ||||
basic_ifstream::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> / this file is called main.cpp bool file_exists(const std::string& str) { std::ifstream fs(str); return fs.is_open(); } int main() { std::boolalpha(std::cout); std::cout << file_exists("main.cpp") << '\n' << file_exists("strange_file") << '\n'; }
Possible output:
true false
[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] |