pub struct BufWriter<W>{ /* private fields */ }
Expand description
Wraps a writer and buffers its output.
It can be excessively inefficient to work directly with something that
implements Write
. For example, every call to
write
on TcpStream
results in a system call. A
BufWriter<W>
keeps an in-memory buffer of data and writes it to an underlying
writer in large, infrequent batches.
BufWriter<W>
can improve the speed of programs that make small and
repeated write calls to the same file or network socket. It does not
help when writing very large amounts at once, or writing just one or a few
times. It also provides no advantage when writing to a destination that is
in memory, like a Vec<u8>
.
It is critical to call flush
before BufWriter<W>
is dropped. Though
dropping will attempt to flush the contents of the buffer, any errors
that happen in the process of dropping will be ignored. Calling flush
ensures that the buffer is empty and thus dropping will not even attempt
file operations.
§Examples
Let’s write the numbers one through ten to a TcpStream
:
use std::io::prelude::*;
use std::net::TcpStream;