原文链接:https://doc.rust-lang.org/nomicon/vec-dealloc.html

回收资源

接下来我们应该实现Drop,否则就要造成大量的资源泄露了。最简单的方法是循环调用pop直到产生None为止,然后再回收我们的缓存。注意,当T: !Drop的时候,调用pop不是必须的。理论上我们可以问一问RustT是不是need_drop然后再省略一些pop调用。可实际上LLVM很擅长移除像这样的无副作用的代码,所以我们不需要再做多余的事,除非你发现LLVM不能成功移除(在这里它能)。

self.cap == 0的时候,我们一定不要调用heap::deallocate,因为这时我们还没有实际分配过任何内存。

  1. impl<T> Drop for Vec<T> {
  2. fn drop(&mut self) {
  3. if self.cap != 0 {
  4. while let Some(_) = self.pop() { }
  5. let align = mem::align_of::<T>();
  6. let elem_size = mem::size_of::<T>();
  7. let num_bytes = elem_size * self.cap;
  8. unsafe {
  9. heap::deallocate(self.ptr.as_ptr() as *mut _, num_bytes, align);
  10. }
  11. }
  12. }
  13. }