Struct tokio::io::BufStream [−][src]
pub struct BufStream<RW> { /* fields omitted */ }
Wraps a type that is AsyncWrite
and AsyncRead
, and buffers its input and output.
It can be excessively inefficient to work directly with something that implements AsyncWrite
and AsyncRead
. For example, every write
, however small, has to traverse the syscall
interface, and similarly, every read has to do the same. The BufWriter
and BufReader
types aid with these problems respectively, but do so in only one direction. BufStream
wraps
one in the other so that both directions are buffered. See their documentation for details.
Implementations
impl<RW: AsyncRead + AsyncWrite> BufStream<RW>
[src]
impl<RW: AsyncRead + AsyncWrite> BufStream<RW>
[src]pub fn new(stream: RW) -> BufStream<RW>
[src]
Wraps a type in both BufWriter
and BufReader
.
See the documentation for those types and BufStream
for details.
pub fn with_capacity(
reader_capacity: usize,
writer_capacity: usize,
stream: RW
) -> BufStream<RW>
[src]
reader_capacity: usize,
writer_capacity: usize,
stream: RW
) -> BufStream<RW>
Creates a BufStream
with the specified BufReader
capacity and BufWriter
capacity.
See the documentation for those types and BufStream
for details.
pub fn get_ref(&self) -> &RWⓘ
[src]
Gets a reference to the underlying I/O object.
It is inadvisable to directly read from the underlying I/O object.
pub fn get_mut(&mut self) -> &mut RWⓘ
[src]
Gets a mutable reference to the underlying I/O object.
It is inadvisable to directly read from the underlying I/O object.
pub fn get_pin_mut(self: Pin<&mut Self>) -> Pin<&mut RW>ⓘ
[src]
Gets a pinned mutable reference to the underlying I/O object.
It is inadvisable to directly read from the underlying I/O object.
pub fn into_inner(self) -> RW
[src]
Consumes this BufStream
, returning the underlying I/O object.
Note that any leftover data in the internal buffer is lost.
Trait Implementations
impl<RW: AsyncRead + AsyncWrite> AsyncBufRead for BufStream<RW>
[src]
impl<RW: AsyncRead + AsyncWrite> AsyncBufRead for BufStream<RW>
[src]impl<RW: AsyncRead + AsyncWrite> AsyncRead for BufStream<RW>
[src]
impl<RW: AsyncRead + AsyncWrite> AsyncRead for BufStream<RW>
[src]impl<RW: AsyncRead + AsyncWrite + AsyncSeek> AsyncSeek for BufStream<RW>
[src]
impl<RW: AsyncRead + AsyncWrite + AsyncSeek> AsyncSeek for BufStream<RW>
[src]Seek to an offset, in bytes, in the underlying stream.
The position used for seeking with SeekFrom::Current(_)
is the
position the underlying stream would be at if the BufStream
had no
internal buffer.
Seeking always discards the internal buffer, even if the seek position
would otherwise fall within it. This guarantees that calling
.into_inner()
immediately after a seek yields the underlying reader
at the same position.
See AsyncSeek
for more details.
Note: In the edge case where you’re seeking with SeekFrom::Current(n)
where n
minus the internal buffer length overflows an i64
, two
seeks will be performed instead of one. If the second seek returns
Err
, the underlying reader will be left at the same position it would
have if you called seek
with SeekFrom::Current(0)
.
impl<RW: AsyncRead + AsyncWrite> AsyncWrite for BufStream<RW>
[src]
impl<RW: AsyncRead + AsyncWrite> AsyncWrite for BufStream<RW>
[src]fn poll_write(
self: Pin<&mut Self>,
cx: &mut Context<'_>,
buf: &[u8]
) -> Poll<Result<usize>>
[src]
self: Pin<&mut Self>,
cx: &mut Context<'_>,
buf: &[u8]
) -> Poll<Result<usize>>
fn poll_write_vectored(
self: Pin<&mut Self>,
cx: &mut Context<'_>,
bufs: &[IoSlice<'_>]
) -> Poll<Result<usize>>
[src]
self: Pin<&mut Self>,
cx: &mut Context<'_>,
bufs: &[IoSlice<'_>]
) -> Poll<Result<usize>>
fn is_write_vectored(&self) -> bool
[src]
fn poll_flush(self: Pin<&mut Self>, cx: &mut Context<'_>) -> Poll<Result<()>>
[src]
fn poll_shutdown(self: Pin<&mut Self>, cx: &mut Context<'_>) -> Poll<Result<()>>
[src]
impl<'__pin, RW> Unpin for BufStream<RW> where
__Origin<'__pin, RW>: Unpin,
[src]
__Origin<'__pin, RW>: Unpin,
Auto Trait Implementations
impl<RW> RefUnwindSafe for BufStream<RW> where
RW: RefUnwindSafe,
RW: RefUnwindSafe,
impl<RW> Send for BufStream<RW> where
RW: Send,
RW: Send,
impl<RW> Sync for BufStream<RW> where
RW: Sync,
RW: Sync,
impl<RW> UnwindSafe for BufStream<RW> where
RW: UnwindSafe,
RW: UnwindSafe,