# list_tools
## 介绍
[`List`]是一个基于“struct递归”的结构体,他由于不基于`Rust`自带的[`Vec`],所以作者得从零搭建:)。有不好的地方可以自己写(VSCode里Ctrl+左键)
已发布:
+ 0.1.0: 添加List
+ 0.1.1: 给List添加reverse
+ 0.1.2: 修改0.1.1
+ 0.1.3: 给List添加Iter
+ 0.1.4: 给List添加Add trait+Sub trait+find+sorted+mut_sorted
+ 0.1.5: 实现ErrorType<-->(usize, String),给List实现reserve+reserve_mut+slice_to_list+Neg,增加模块组fast_tools
+ 0.1.6: 实现ErrorType<-->[String; 2],
+ 0.1.7: 给List实现swap_of_index, swap_of_t
crate地址:https://crates.io/crates/list_tools
gitee地址:https://gitee.com/yizili/list_tools/edit/master
## Examples
```rust
use list_tools::{clist, List};
let mut l: List<u8> = clist!(1, 1, 2, 4);
l.remove_index(0);
l.append_of_end(5);
l.append_of_front(0);
l.append_of_index(3, 3);
assert_eq!(Vec::from(l.clone()), vec![0, 1, 2, 3, 4, 5]);
assert_eq!(&l, &clist!(0, 1, 2, 3, 4, 5));
assert_ne!(&l, &clist!());
println!("{}", l);
println!("{:?}", l);
println!("{:#?}", l);
// --snip--
println!("---snip---");
let mut l = clist!(0; 10);
assert_eq!(l, clist!(0, 0, 0, 0, 0, 0, 0, 0, 0, 0));
println!("{}", l);
println!("{:?}", l);
println!("{:#?}", l);
assert_eq!(l.reverse(), clist!(0; 10));
l.clear();
assert_eq!(l, List::new());
```
# 其他
反馈发邮箱:3396311242@qq.com