我正在尝试使用。我的程序中的“键”的强类型包装器,这样我就不会将任意字符串误认为是键。我有:
#[derive(Debug, Clone, PartialEq, Eq, Hash)]
struct Key(String);
我有一个HashMap<Key, _>
, 并且我想通过对键类型的引用来查找值(即不必拥有该字符串)。看来我需要做的是:
- 为我的密钥创建一个“ref”类型:
#[derive(Debug, Clone, PartialEq, Eq, Hash)]
struct KeyRef<'a>(&'a String);
(实际上我想要KeyRef<'a>(&'a str)
,但使用String
可以作为一个更清晰的例子)
- 实施
Borrow<KeyRef<'_>> for Key
我已经尽力了,这是一个游乐场链接
我最明确的尝试(注释所有生命周期)是:
impl<'a> Borrow<KeyRef<'a>> for Key {
fn borrow<'b>(&'b self) -> &'b KeyRef<'a> where 'b: 'a {
let string_ref : &'a String = &self.0;
let key_ref : &'a KeyRef<'a> = &KeyRef(string_ref);
key_ref
}
}
这给了我错误:“方法的生命周期参数或边界borrow
与特征声明不匹配”。
直觉上感觉这应该是可能的:
- KeyRef 持有生命周期的引用
'a
,因此 KeyRef 的任何值都不能超过生命周期'a
。 - in
fn borrow<'b>(&'b self)
,由于上述原因,'b
不能大于'a
但是编译器似乎不喜欢我明确尝试证明 (with where 'b: 'a
),并且将其关闭我得到“由于要求冲突,无法推断借用表达式的适当生命周期”