Struct std::io::IntoInnerError1.0.0[][src]

pub struct IntoInnerError<W>(_, _);
Expand description

BufWriter::into_inner 返回的错误,将写出缓冲区时发生的错误与缓冲的 writer object 结合在一起,可用于从条件中恢复。

Examples

use std::io::BufWriter;
use std::net::TcpStream;

let mut stream = BufWriter::new(TcpStream::connect("127.0.0.1:34254").unwrap());

// 用流做东西

// 我们想取回 `TcpStream`,所以让我们尝试:

let stream = match stream.into_inner() {
    Ok(s) => s,
    Err(e) => {
        // 在这里,e 是一个 IntoInnerError
        panic!("An error occurred");
    }
};
Run

Implementations

返回导致 BufWriter::into_inner() 调用失败的错误。

尝试写入内部缓冲区时返回此错误。

Examples

use std::io::BufWriter;
use std::net::TcpStream;

let mut stream = BufWriter::new(TcpStream::connect("127.0.0.1:34254").unwrap());

// 用流做东西

// 我们想取回 `TcpStream`,所以让我们尝试:

let stream = match stream.into_inner() {
    Ok(s) => s,
    Err(e) => {
        // 在这里,e 是一个 IntoInnerError,让我们记录内部错误。
        // 在此示例中,我们仅将 'log' 更改为 stdout。
        println!("{}", e.error());

        panic!("An unexpected error occurred.");
    }
};
Run

返回产生错误的缓冲 writer 实例。

返回的 object 可用于错误恢复,例如重新检查缓冲区。

Examples

use std::io::BufWriter;
use std::net::TcpStream;

let mut stream = BufWriter::new(TcpStream::connect("127.0.0.1:34254").unwrap());

// 用流做东西

// 我们想取回 `TcpStream`,所以让我们尝试:

let stream = match stream.into_inner() {
    Ok(s) => s,
    Err(e) => {
        // 在这里,e 是一个 IntoInnerError,让我们重新检查缓冲区:
        let buffer = e.into_inner();

        // 做一些事情来尝试恢复

        // 之后,让我们返回流
        buffer.into_inner().unwrap()
    }
};
Run

消耗 IntoInnerError 并返回导致 BufWriter::into_inner() 调用失败的错误。 与 error 不同,它可用于获取基本错误的所有权。

Example

use std::io::{BufWriter, ErrorKind, Write};

let mut not_enough_space = [0u8; 10];
let mut stream = BufWriter::new(not_enough_space.as_mut());
write!(stream, "this cannot be actually written").unwrap();
let into_inner_err = stream.into_inner().expect_err("now we discover it's too small");
let err = into_inner_err.into_error();
assert_eq!(err.kind(), ErrorKind::WriteZero);
Run

消耗 IntoInnerError 并返回导致 BufWriter::into_inner() 调用失败的错误,以及返回的 writer。

这可以用来简单地获取潜在错误的所有权。它也可以用于高级错误恢复。

Example

use std::io::{BufWriter, ErrorKind, Write};

let mut not_enough_space = [0u8; 10];
let mut stream = BufWriter::new(not_enough_space.as_mut());
write!(stream, "this cannot be actually written").unwrap();
let into_inner_err = stream.into_inner().expect_err("now we discover it's too small");
let (err, recovered_writer) = into_inner_err.into_parts();
assert_eq!(err.kind(), ErrorKind::WriteZero);
assert_eq!(recovered_writer.buffer(), b"t be actually written");
Run

Trait Implementations

使用给定的格式化程序格式化该值。 Read more

使用给定的格式化程序格式化该值。 Read more

👎 Deprecated since 1.42.0:

use the Display impl or to_string()

此错误的下级来源 (如果有)。 Read more

🔬 This is a nightly-only experimental API. (backtrace #53487)

返回发生错误的栈回溯 (如果有)。 Read more

👎 Deprecated since 1.33.0:

replaced by Error::source, which can support downcasting

执行转换。

Auto Trait Implementations

Blanket Implementations

获取 selfTypeIdRead more

从拥有的值中一成不变地借用。 Read more

从拥有的值中借用。 Read more

执行转换。

执行转换。

将给定值转换为 StringRead more

发生转换错误时返回的类型。

执行转换。

发生转换错误时返回的类型。

执行转换。