为什么 i32 Box 类型可以在 Rust 中向下转型?

fls*_*fls 2 rust

我们可以使用std::any::Any将不同类型收集到一个Box.

use std::any::Any;

fn foo(value: Box<dyn Any>) {
    if let Some(string) = value.downcast_ref::<String>() {
        println!("String: {}", *string);
    } else if let Some(int) = value.downcast_ref::<i32>() {
        println!("i32: {}", *int);
    }
}

fn main() {
    let x = Box::new("hello".to_owned());
    let y = Box::new(123);
    foo(x);
    foo(y);
}
Run Code Online (Sandbox Code Playgroud)

我们还可以用来downcast识别 a 中值的类型Box。我了解到C++中的类型可以通过虚函数来确定,根据这个问题,RTTI是如何工作的?。然而,类似的类型i32在 Rust 中也可以被向下转型。它是如何工作的?

Apl*_*123 5

当你let y = Box::new(123)在这里这样做时,y被推断为是Box<dyn Any>而不是 Box<i32>。这本质上等同于编写let y = Box::new(123) as Box<dyn Any>,这可能会让发生的事情更加明显:您在构造它时将盒子向上转换以添加 typeid ,i32以便稍后可以将其向下转换回来。