# File I/O | |
The `File` struct represents a file that has been opened (it wraps a file | |
descriptor), and gives read and/or write access to the underlying file. | |
Since many things can go wrong when doing file I/O, all the `File` methods | |
return the `io::Result<T>` type, which is an alias for `Result<T, io::Error>`. | |
This makes the failure of all I/O operations *explicit*. Thanks to this, the | |
programmer can see all the failure paths, and is encouraged to handle them in | |
a proactive manner. |