实现泛型类型的均值函数

use*_*784 4 generics rust

我正在尝试编写一个函数来返回a的平均值Vector.我希望它与泛型类型一起工作,但我在实现它时遇到了一些困难.

extern crate num; // 0.2.0

use num::Zero;
use std::ops::{Add, Div};

pub struct Vector<T> {
    pub size: usize,
    pub data: Vec<T>,
}

impl<T: Copy + Zero + Add<T, Output = T>> Vector<T> {
    pub fn sum(&self) -> T {
        self.data.iter().fold(T::zero(), |sum, &val| sum + val)
    }
}

impl<T: Copy + Zero + Add<T, Output = T> + Div<T, Output = T>> Vector<T> {
    pub fn mean(&self) -> T {
        let sum = self.sum();
        sum / self.data.len()
    }
}
Run Code Online (Sandbox Code Playgroud)

游乐场.

上面的例子中不编译为self.data.len()是一个usizesum类型为T:

error[E0308]: mismatched types
  --> src/lib.rs:20:15
   |
20 |         sum / self.data.len()
   |               ^^^^^^^^^^^^^^^ expected type parameter, found usize
   |
   = note: expected type `T`
              found type `usize`
Run Code Online (Sandbox Code Playgroud)

我知道我可以将签名更改为:

impl<T: Copy + Zero + Add<T, Output = T> + Div<usize, Output = T>> Vector<T>
Run Code Online (Sandbox Code Playgroud)

它会编译 - 但这不是针对Rust原始类型实现的.我该怎么办呢?

Fra*_*gné 5

原始类型实现FromPrimitive性状,所限定num板条箱,以允许原始类型之间的转换,包括usize.我们可以FromPrimitive在函数上添加一个绑定,然后我们可以将其转换usizeT:

extern crate num; // 0.2.0

use num::{FromPrimitive, Zero};
use std::ops::{Add, Div};

impl<T> Vector<T>
where
    T: Copy + Zero + Add<T, Output = T> + Div<T, Output = T> + FromPrimitive,
{
    pub fn mean(&self) -> T {
        let sum = self.sum();
        sum / FromPrimitive::from_usize(self.data.len()).unwrap()
    }
}
Run Code Online (Sandbox Code Playgroud)