0

我刚刚开始学习 Rust 并阅读 Rust 书。其中一章通过几个示例引导,并以“尝试使这种通用”类型的建议练习结束。我一直在全力以赴。您开始使用的半通用类型是这样的:

struct Cacher<T>
    where T: Fn(i32) -> i32
{
    value: Option<i32>,
    // leaving out rest for brevity

然后我开始转换它,以便 Fn 特征也是通用的,这也直接影响“价值”。所以这就是我想出的:

struct Cacher<T, U>
    where T: Fn(U) -> U
{
    calculation: T,
    value: Option<U>,
}

impl<T, U> Cacher<T, U>
    where T: Fn(U) -> U
{
    fn new(calculation: T) -> Cacher<T, U> {
        Cacher {
            calculation,
            value: Option::None,
        }
    }

    fn value(&mut self, arg: U) -> &U {
        match self.value {
            Some(ref v) => v,
            None => {
              let v = (self.calculation)(arg);
              self.value = Some(v);
              // problem is returning reference to value that was in
              // v which is now moved, and unwrap doesn't seem to work...
            },
        }
    }
}

我所有的问题都在 fn value getter 中。我不确定我是否已经接近了,或者我只是走上了完全错误的道路。那么我要在哪里出轨呢?

4

1 回答 1

1

并且 unwrap 似乎不起作用...

问题是unwrap它的参数是按值取值的,所以它会被移动。

类似的东西self.value.as_ref().unwrap()应该可以解决问题。

于 2017-09-02T17:54:21.610 回答