在模板中具有关联类型的特征

ygg*_*gie 3 rust

我在编译Rust代码时遇到了问题,我设法将问题归结为这个代码片段:

use std::slice::Iter;

pub trait Foo<'a> {
    type Bar: Iterator<Item=&'a usize>;

    fn make(&self) -> usize;
}

pub struct Juice;

impl <'a> Foo<'a> for Juice {
    type Bar = Iter<'a, usize>;

    fn make(&self) -> usize { 0us }
}


// Uncomment this line to break things
// fn get_int<'a, T: Foo<'a>>(t: T) -> usize {
//   t.make()
// }


fn main() {
    println!("Hello, {:?} world!" , Juice.make());
}
Run Code Online (Sandbox Code Playgroud)

我很确定我只是遗漏了一些东西,我需要做些什么来使这个特性发挥作用?我正在使用最新的每晚alpha版本(在撰写本文时):

rustc 1.0.0-nightly (458a6a2f6 2015-01-25 21:20:37 +0000)
Run Code Online (Sandbox Code Playgroud)

Vla*_*eev 5

不幸的是,你需要写这个:

fn get_int<'a, T: Foo<'a, Bar=I>, I: Iterator<Item=&'a usize>>(t: T) -> usize {
  t.make()
}
Run Code Online (Sandbox Code Playgroud)

也就是说,您必须明确指定类型Bar是相应类型的迭代器.单独在特质定义内的特征是不够的.

这非常类似于常规类型参数的工作.即使你写了类似的东西

trait Parameterized<T: Clone> { ... }
Run Code Online (Sandbox Code Playgroud)

你还需要写

fn do_something<P: Parameterized<T>, T: Clone>() { ... }
Run Code Online (Sandbox Code Playgroud)

或结构:

struct S<T: Iterator<i32>> { ... }

impl<T: Iterator<i32>> for S<T> { ... }
Run Code Online (Sandbox Code Playgroud)

这确实看起来违反直觉(我也偶然发现了几次)并且可能在RFC repo中存在问题.