2 回答

TA貢獻(xiàn)1805條經(jīng)驗(yàn) 獲得超10個(gè)贊
impl Trait不等同于返回接口或基類(lèi)對(duì)象。這是說(shuō)“我不想寫(xiě)我要返回的特定類(lèi)型的名稱(chēng)”的一種方式。您仍在返回單個(gè)特定類(lèi)型的值。您只是沒(méi)有說(shuō)哪種類(lèi)型。
這些分支中的每一個(gè)都返回不同的類(lèi)型,因此出現(xiàn)了問(wèn)題。僅僅實(shí)現(xiàn)相同的特征是不夠的。
在這種特定情況下,您可能需要的是trait對(duì)象Box<dyn RngCore>。
extern crate rand; // 0.6.5
use rand::{rngs::OsRng, thread_rng, RngCore};
fn rng() -> Box<dyn RngCore> {
match OsRng::new() {
Ok(rng) => Box::new(rng),
Err(_) => Box::new(thread_rng()),
}
}
注意:如果您使用的是Rust的舊版本,則可能需要?jiǎng)h除dyn關(guān)鍵字。在當(dāng)前(2015)版本的Rust中,它是可選的。

TA貢獻(xiàn)1862條經(jīng)驗(yàn) 獲得超7個(gè)贊
DK。已經(jīng)解釋了為什么,但是我想提供一個(gè)替代的解決方法。
正如提到有條件迭代在幾個(gè)可能的迭代器一個(gè),您可以創(chuàng)建如果同時(shí)它的組件類(lèi)型做一個(gè)實(shí)現(xiàn)特征的枚舉。例如:
extern crate rand; // 0.6.5
use rand::{rngs::OsRng, thread_rng, RngCore};
fn rng() -> impl RngCore {
match OsRng::new() {
Ok(rng) => EitherRng::Left(rng),
Err(_) => EitherRng::Right(thread_rng()),
}
}
enum EitherRng<L, R> {
Left(L),
Right(R),
}
impl<L, R> RngCore for EitherRng<L, R>
where
L: RngCore,
R: RngCore,
{
fn next_u32(&mut self) -> u32 {
match self {
EitherRng::Left(l) => l.next_u32(),
EitherRng::Right(r) => r.next_u32(),
}
}
fn next_u64(&mut self) -> u64 {
match self {
EitherRng::Left(l) => l.next_u64(),
EitherRng::Right(r) => r.next_u64(),
}
}
fn fill_bytes(&mut self, b: &mut [u8]) {
match self {
EitherRng::Left(l) => l.fill_bytes(b),
EitherRng::Right(r) => r.fill_bytes(b),
}
}
fn try_fill_bytes(&mut self, b: &mut [u8]) -> Result<(), rand::Error> {
match self {
EitherRng::Left(l) => l.try_fill_bytes(b),
EitherRng::Right(r) => r.try_fill_bytes(b),
}
}
}
在任一箱提供了很多這些類(lèi)型的基本特征實(shí)現(xiàn)的。
- 2 回答
- 0 關(guān)注
- 659 瀏覽
添加回答
舉報(bào)