运行以下代码将导致编译器提示 PairedNumbers::get
返回 (char, char)
而不是 (&char, &char)
:
use std::iter::{Zip, Cycle, Skip};
use std::str::Chars;
struct PairedNumbers<'a> {
char_pairs: Zip<Cycle<Chars<'a>>, Skip<Cycle<Chars<'a>>>>,
counter: usize,
}
impl<'a, 'b: 'a> PairedNumbers<'a> {
fn new(num_str: &'b str, jump: usize) -> PairedNumbers<'a> {
PairedNumbers {
char_pairs: num_str.chars().cycle().zip(num_str.chars().cycle().skip(jump)),
counter: 0,
}
}
fn get(&'a mut self) -> (&'a char, &'a char) {
self.counter = self.counter + 1;
self.char_pairs.next().expect("could not get char pair from unparsed_pairs!")
}
}
我们看到 PairedNumbers
通过在字符串切片的字符上创建迭代器(具体为 Chars
)来初始化结构。鉴于 &str
是对特定内存区域的引用(我假设是连续区域?),不会 Chars
确实在迭代对组件的引用 char
组成 str
的 s ? Rust 的自动解除引用在这里起作用了吗?
最佳答案
A &str
指向 UTF-8 编码的字符序列;由于它们是经过编码的,因此您无法获得导致对解码字符的引用的迭代器,解码字符需要按值返回。
另请参阅 Iterator
impl for std::str::Chars
的 Item
类型.
关于rust - 为什么 `Item` 迭代器的 `Char` 是通过在字符串切片上调用 `chars` 而获得的,而不是对 `char` 的引用?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/47622748/