pub struct LineWriter<W: Write> { /* fields omitted */ }
Wraps a writer and buffers output to it, flushing whenever a newline
(0x0a
, '\n'
) is detected.
The BufWriter
struct wraps a writer and buffers its output.
But it only does this batched write when it goes out of scope, or when the
internal buffer is full. Sometimes, you'd prefer to write each line as it's
completed, rather than the entire buffer at once. Enter LineWriter
. It
does exactly that.
Like BufWriter
, a LineWriter
’s buffer will also be flushed when the
LineWriter
goes out of scope or when its internal buffer is full.
If there's still a partial line in the buffer when the LineWriter
is
dropped, it will flush those contents.
We can use LineWriter
to write one line at a time, significantly
reducing the number of actual writes to the file.
use std::fs::{self, File};
use std::io::prelude::*;
use std::io::LineWriter;
fn main() -> std::io::Result<()> {
let road_not_taken = b"I shall be telling this with a sigh
Somewhere ages and ages hence:
Two roads diverged in a wood, and I -
I took the one less traveled by,
And that has made all the difference.";
let file = File::create("poem.txt")?;
let mut file = LineWriter::new(file);
file.write_all(b"I shall be telling this with a sigh")?;
assert_eq!(fs::read_to_string("poem.txt")?, "");
file.write_all(b"\n")?;
assert_eq!(
fs::read_to_string("poem.txt")?,
"I shall be telling this with a sigh\n",
);
file.write_all(b"Somewhere ages and ages hence:
Two roads diverged in a wood, and I -
I took the one less traveled by,
And that has made all the difference.")?;
file.flush()?;
assert_eq!(fs::read("poem.txt")?, &road_not_taken[..]);
Ok(())
}Run
Creates a new LineWriter
.
use std::fs::File;
use std::io::LineWriter;
fn main() -> std::io::Result<()> {
let file = File::create("poem.txt")?;
let file = LineWriter::new(file);
Ok(())
}Run
Creates a new LineWriter
with a specified capacity for the internal
buffer.
use std::fs::File;
use std::io::LineWriter;
fn main() -> std::io::Result<()> {
let file = File::create("poem.txt")?;
let file = LineWriter::with_capacity(100, file);
Ok(())
}Run
Gets a reference to the underlying writer.
use std::fs::File;
use std::io::LineWriter;
fn main() -> std::io::Result<()> {
let file = File::create("poem.txt")?;
let file = LineWriter::new(file);
let reference = file.get_ref();
Ok(())
}Run
Gets a mutable reference to the underlying writer.
Caution must be taken when calling methods on the mutable reference
returned as extra writes could corrupt the output stream.
use std::fs::File;
use std::io::LineWriter;
fn main() -> std::io::Result<()> {
let file = File::create("poem.txt")?;
let mut file = LineWriter::new(file);
let reference = file.get_mut();
Ok(())
}Run
Unwraps this LineWriter
, returning the underlying writer.
The internal buffer is written out before returning the writer.
An Err
will be returned if an error occurs while flushing the buffer.
use std::fs::File;
use std::io::LineWriter;
fn main() -> std::io::Result<()> {
let file = File::create("poem.txt")?;
let writer: LineWriter<File> = LineWriter::new(file);
let file: File = writer.into_inner()?;
Ok(())
}Run
Write a buffer into this object, returning how many bytes were written. Read more
Flush this output stream, ensuring that all intermediately buffered contents reach their destination. Read more
Attempts to write an entire buffer into this write. Read more
Writes a formatted string into this writer, returning any error encountered. Read more
Creates a "by reference" adaptor for this instance of Write
. Read more
Formats the value using the given formatter. Read more
type Error = !
🔬 This is a nightly-only experimental API. (
try_from
#33417)
The type returned in the event of a conversion error.
🔬 This is a nightly-only experimental API. (
try_from
#33417)
type Error = <U as TryFrom<T>>::Error
🔬 This is a nightly-only experimental API. (
try_from
#33417)
The type returned in the event of a conversion error.
🔬 This is a nightly-only experimental API. (
try_from
#33417)
Immutably borrows from an owned value. Read more
Mutably borrows from an owned value. Read more
🔬 This is a nightly-only experimental API. (get_type_id
#27745)
this method will likely be replaced by an associated static