rust panicked

 

 

use std::thread;
use std::time;
use std::sync::mpsc;

fn main() {
    let (tx, rx) : (mpsc::Sender<i32>, mpsc::Receiver<i32>)  = mpsc::channel();
    //drop(rx);
    thread::spawn(move || {
        let val = 99;
                let sendinfo = tx.send(val);
        //tx.send(val).unwrap();
                if let Err(v) = sendinfo {
                    
               println!("err inof  {}", v);
                }
    });
    thread::sleep(time::Duration::from_secs(5));
    let received = rx.recv().unwrap();
    println!("Got: {}", received);
    let received = rx.recv().unwrap();
}

 

Got: 99
thread 'main' panicked at 'called `Result::unwrap()` on an `Err` value: RecvError', src/main.rs:20:30
note: run with `RUST_BACKTRACE=1` environment variable to display a backtrace
[root@bogon channel]# cat src/main.rs 

 

 

use std::thread;
use std::time;
use std::sync::mpsc;

fn main() {
    let (tx, rx) : (mpsc::Sender<i32>, mpsc::Receiver<i32>)  = mpsc::channel();
    //drop(rx);
    thread::spawn(move || {
        let val = 99;
                let sendinfo = tx.send(val);
        //tx.send(val).unwrap();
                if let Err(v) = sendinfo {
                    
               println!("err inof  {}", v);
                }
    });
    thread::sleep(time::Duration::from_secs(5));
    let received = rx.recv();
        if let Err(v) = received {
                    
               println!("err inof  {}", v);
                }else {
               println!("recv info  ");
                }
    let received2 = rx.recv().unwrap();
}

 

 

recv info  
thread 'main' panicked at 'called `Result::unwrap()` on an `Err` value: RecvError', src/main.rs:25:31
note: run with `RUST_BACKTRACE=1` environment variable to display a backtrace

 

use std::thread;
use std::time;
use std::sync::mpsc;

fn main() {
    let (tx, rx) : (mpsc::Sender<i32>, mpsc::Receiver<i32>)  = mpsc::channel();
    //drop(rx);
    thread::spawn(move || {
        let val = 99;
                let sendinfo = tx.send(val);
        //tx.send(val).unwrap();
                if let Err(v) = sendinfo {
                    
               println!("err inof  {}", v);
                }
    });
    thread::sleep(time::Duration::from_secs(5));
    let received = rx.recv();
        if let Err(v) = received {
                    
               println!("err inof  {}", v);
                }else {
               println!("recv info  ");
                }
    let received2 = rx.recv();
        if let Err(v) = received2 {
                    
               println!("err inof  {}", v);
                }
}

 

 

    Finished dev [unoptimized + debuginfo] target(s) in 0.01s
     Running `target/debug/own`
recv info  
err inof  receiving on a closed channel

 

Result 是 Option 类型的更丰富的版本,描述的是可能 的错误而不是可能的不存在

也就是说,Result<T,E> 可以有两个结果的其中一个:

  • Ok<T>:找到 T 元素
  • Err<E>:找到 E 元素,E 即表示错误的类型。

按照约定,预期结果是 “Ok”,而意外结果是 “Err”。

Result 有很多类似 Option 的方法。例如 unwrap(),它要么举出元素 T,要么就 panic。 对于事件的处理,Result 和 Option 有很多相同的组合算子。

在使用 Rust 时,你可能会遇到返回 Result 类型的方法,例如 parse() 方法。它并不是总能把字符串解析成指定的类型,所以 parse() 返回一个 Result 表示可能的失败。

我们来看看当 parse() 字符串成功和失败时会发生什么:

 
 
 
fn multiply(first_number_str: &str, second_number_str: &str) -> i32 {
// 用 `unwrap()`
let first_number = first_number_str.parse::<i32>().unwrap();
let second_number = second_number_str.parse::<i32>().unwrap();
first_number * second_number
}
 
fn main() {
let twenty = multiply("10", "2");
println!("double is {}", twenty);
 
let tt = multiply("t", "2");
println!("double is {}", tt);
}
 
 
 

在失败的情况下,parse() 产生一个错误,留给 unwrap() 来解包并产生 panic。另 外,panic 会退出我们的程序,并提供一个让人很不爽的错误消息。

为了改善错误消息的质量,我们应该更具体地了解返回类型并考虑显式地处理错误。

 

posted on 2020-12-28 14:30  tycoon3  阅读(169)  评论(0编辑  收藏  举报

导航