Sar*_*tok 4 lambda split vector rust borrowing
fn count_spaces(text: Vec<u8>) -> usize {
text.split(|c| c == 32u8).count()
}
Run Code Online (Sandbox Code Playgroud)
上面的函数无法编译,并在比较时给出以下错误:
特征 `&u8: std::cmp::PartialEq` 不满足
我将其读为:“c是借用的字节,无法与常规字节进行比较”,但我一定读错了。
根据特定值拆分 a 的适当方法是什么Vec<u8>?
我确实意识到在读取文件时有一些选项,比如分割 aBufReader或者我可以将向量转换为字符串并使用str::split. 我可能会采用这样的解决方案(传递 aBufReader而不是 a Vec<u8>),但现在我只是在玩,测试东西并想知道我做错了什么。
您实际上没有看错:c确实是借用的字节,无法与常规字节进行比较。尝试使用以下任意函数:
fn count_spaces(text: Vec<u8>) -> usize {
text.split(|&c| c == 32u8).count()
}
fn count_spaces(text: Vec<u8>) -> usize {
text.split(|c| *c == 32u8).count()
}
Run Code Online (Sandbox Code Playgroud)
第一个使用参数 ( &c) 上的模式匹配来取消引用它,而第二个则使用取消引用运算符 ( *)。
ca&u8而不是a u8?如果您查看文档上的split方法,您会发现闭包参数是借用Vec. 在这种情况下,这意味着参数将被&u8代替u8(所以在你的代码中你实际上是在&u8与进行比较u8,这是 Rust 不喜欢的)。
为了理解为什么闭包通过借用而不是通过值获取参数,请考虑如果通过值获取参数会发生什么。这样的话,实施起来Vec<u8>就没有问题了。然而,在 aa 的情况下,每个都将被移入闭包并被销毁!u8CopyVec<String>String