【发布时间】:2020-10-17 01:01:16
【问题描述】:
我正在编写一个非常简单的递归程序来查找两个数之间的所有素数:
use std::cmp::PartialOrd;
use std::ops::{Add, Div, Rem, Sub};
fn _is_prime<T>(n: T, dividend: T, one: T) -> bool
where
T: Copy + Rem<Output = T> + Sub<Output = T> + PartialOrd,
{
if dividend == one {
true
} else {
if n % dividend < one {
false
} else {
_is_prime(n, dividend - one, one)
}
}
}
fn _primes_between<'a, T>(a: T, b: T, one: T, v: &'a mut Vec<T>) -> &'a mut Vec<T>
where
T: Copy + Rem<Output = T> + Add<Output = T> + Sub<Output = T> + PartialOrd,
{
if a <= b {
if _is_prime(a, a - one, one) {
v.push(a);
}
_primes_between(a + one, b, one, v)
} else {
v
}
}
fn primes_between<T>(a: T, b: T) -> Vec<T>
where
T: Copy + Div<Output = T> + Rem<Output = T> + Add<Output = T> + Sub<Output = T> + PartialOrd,
{
let one = a / a;
let mut v: Vec<T> = Vec::new();
*_primes_between(a, b, one, &mut v)
}
fn main() {
primes_between(3, 13).iter().for_each(|i| println!("{}", i));
}
问题是:
error[E0507]: cannot move out of a mutable reference
--> src/main.rs:42:5
|
42 | *_primes_between(a, b, one, &mut v)
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ move occurs because value has type `std::vec::Vec<T>`, which does not implement the `Copy` trait
我该如何解决这个错误?
【问题讨论】:
-
与您的问题无关,但在 Rust 中,
_前缀对于隐私来说不是必需的,因为有pub关键字,因此它获得了“未使用”的含义。经验丰富的 Rustacean 不会将函数命名为_primes_between和_is_prime。除了使用pub,你可以做的另一件事来限制可见性是在其他函数中声明函数,如果它们没有在其他地方使用。
标签: rust