0030-Rust-自实现迭代器

环境

  • Time 2022-05-21
  • Rust 1.61.0

前言

说明

参考:https://doc.rust-lang.org/std/iter/index.html

目标

接前一节,之前迭代都是直接拿走所有权,有时候只需要借用而不需要所有权。

自定义类型

#[derive(Debug)]
struct MyData<T: Debug> {
    value1: T,
    value2: T,
    value3: T,
    value4: T,
}

new

impl<T: Debug> MyData<T> {
    fn new(v1: T, v2: T, v3: T, v4: T) -> Self {
        Self {
            value1: v1,
            value2: v2,
            value3: v3,
            value4: v4,
        }
    }
}

实现迭代器

struct Iter<T>(Vec<T>);

impl<T> Iterator for Iter<T> {
    type Item = T;
    fn next(&mut self) -> Option<Self::Item> {
        self.0.pop()
    }
}

生成迭代器

impl<T: Debug> IntoIterator for MyData<T> {
    type Item = T;
    type IntoIter = Iter<T>;
    fn into_iter(self) -> Iter<T> {
        let vec = vec![self.value4, self.value3, self.value2, self.value1];
        Iter(vec)
    }
}

不取所有权

impl<T: Debug> MyData<T> {
    fn iter(&self) -> Iter<&T> {
        let vec = vec![&self.value4, &self.value3, &self.value2, &self.value1];
        Iter(vec)
    }
}

使用迭代器

fn main() {
    let my_data = MyData::new(88, 44, 66, 22);
    for value in my_data.iter() {
        println!("value: {value:?}")
    }
    println!("my data:{my_data:?}");

    for value in my_data {
        println!("value: {value:?}")
    }
    // 编译错误,已经被移动
    // println!("my data:{my_data:?}");
}

总结

实现了不取走所有权的迭代器,迭代时只拿到每个元素的引用。

附录

posted @ 2022-08-29 17:55  波尔  阅读(22)  评论(0编辑  收藏  举报