官术网_书友最值得收藏!

  • Rust Programming Cookbook
  • Claus Matzinger
  • 279字
  • 2021-06-24 12:27:49

How it works...

Iterators are a great way of providing advanced capabilities to custom data structures. With their simple, unified interface, collection types can be switched out easily as well and programmers don't have to get used to new APIs for every data structure. 

By implementing the Iterator trait in Steps 1 and 2, it becomes easy to provide exactly the desired access level to a collection's elements. In the case of this recipe (and similar to Vec<T>), it will consume the list entirely and remove the items one by one, starting at the front.

In Step 3, we implement IntoIterator, a trait that makes this construct available to the for loop and other users who call into_iter(). Not every collection implements this trait to provide multiple different iterators; for example, the second iterator of Vec<T> is reference-based, and only accessible via an iter() function on the type. By the way, a reference is a data type, just like the actual instance, so it's all about the type definition in this case. These definitions are made inside the trait implementation with the type Item declaration (so-called associated types: https://doc.rust-lang.org/rust-by-example/generics/assoc_items/types.html). These types are called associated types, and can be referenced using Self::Item—just like generics, but without the added syntax verbosity. 

With these interfaces, you can get access to a large library of functions that only assume a working iterator to be present! Check out Steps 4 and 5 to see the implementation and outcome of using the iterator on a newly created list type. 

We've successfully learned how to implement custom iterators. Now, let's move on to the next recipe.

主站蜘蛛池模板: 休宁县| 浦县| 泸西县| 临高县| 科尔| 汾阳市| 安图县| 南漳县| 湘潭市| 永寿县| 雷州市| 冷水江市| 罗山县| 北京市| 榕江县| 海林市| 长治县| 贺兰县| 永靖县| 宣恩县| 柘荣县| 西宁市| 监利县| 邵武市| 温泉县| 贵州省| 涞水县| 专栏| 中牟县| 镇远县| 田林县| 诸暨市| 洪江市| 凤庆县| 陇川县| 裕民县| 斗六市| 乾安县| 九江县| 类乌齐县| 英超|