如何返回包含通用值的向量

时间:2015-04-11 19:00:57

标签: rust

我正在尝试从函数返回一个向量,但编译器给出了以下错误消息:

 expected `Foo<T>`,
    found `Foo<&str>`
(expected type parameter,
    found &-ptr) [E0308]

我在这里缺少什么?

struct Foo<T> {
    bar: T,
}


fn foos<T>() -> Vec<Foo<T>> {
    vec![
        Foo { bar: "x" },
        Foo { bar: 1 },
    ]
}



fn main() {
    let my_foos: Vec<_> = foos();

    println!("{}", my_foos[0].bar);
}

1 个答案:

答案 0 :(得分:1)

编译器在这里给你一个很好的错误信息:

expected `Foo<T>`,
   found `Foo<&str>`

也就是说,你没有返回一些通用的T,你将返回一个具体的类型。实际上,你不是只返回一种类型,而是试图返回两种不同的类型!

每次解析泛型时,它必须解析为单一类型。也就是说,您可以使用两个foo<T>(a: T, b: T)或两个u32来呼叫bool,但是,每个都有一个。

为了使您的代码以最直接的方式工作,您可以使用枚举。这将创建一个可以具有一组值之一的类型:

struct Foo<T> {
    bar: T,
}

#[derive(Debug)]
enum Bar<'a> {
    Num(i32),
    Str(&'a str),
}

// Note no generics here, we specify the concrete type that this `Foo` is
fn foos() -> Vec<Foo<Bar<'static>>> {
    vec![
        Foo { bar: Bar::Str("x") },
        Foo { bar: Bar::Num(1) },
    ]
}

fn main() {
    let my_foos: Vec<_> = foos();

    println!("{:?}", my_foos[0].bar);
}