介绍

本系列录制的视频主要放在B站上Rust死灵书学习视频

Rust 死灵书相关的源码资料在https://github.com/anonymousGiga/Rustonomicon-Source

Vec内存分配

在上节中我们写了个简化版的Unique,在后面的章节中我们使用nightly版本中的Unique。

使用nightly版本

使用nightly的方法就是在cargo命令之后加上“+nightly”,其它都和直接使用cargo一样。

cargo +nightly new learn_myvec  #创建工程
cargo +nightly run #运行工程

在代码中定义MyVec如下:

#![feature(ptr_internals)]use std::ptr::{Unique, self};pub struct MyVec<T> {ptr: Unique<T>,cap: usize,len: usize,
}

空的Vec内存分配

当我们未初始化分配内存的时候,此时我们应该如何处理?

#![feature(ptr_internals)]
//#![feature(alloc)]
use std::mem;use std::ptr::{Unique, self};pub struct MyVec<T> {ptr: Unique<T>,cap: usize,len: usize,
}impl<T> MyVec<T> {fn new() -> Self {assert!(mem::size_of::<T>() != 0, "还没准备好处理零尺寸类型");  //此处我们先不处理T为零尺寸大小类型的情况MyVec { ptr: Unique::dangling(), len: 0, cap: 0 }}
}fn main() {println!("Hello, world!");
}

需要内存时的分配

上面我们处理了为空时的情况,下面开始讨论需要内存时的情况,大体逻辑如下:

if cap == 0:allocate()cap = 1
else:reallocate()cap *= 2

分配内存时的一种可能的实现:

#![feature(ptr_internals)]
use std::mem;
use std::alloc::{alloc, realloc, Layout, handle_alloc_error};use std::ptr::{Unique, self};pub struct MyVec<T> {ptr: Unique<T>,cap: usize,len: usize,
}impl<T> MyVec<T> {fn new() -> Self {assert!(mem::size_of::<T>() != 0, "还没准备好处理零尺寸类型");MyVec { ptr: Unique::dangling(), len: 0, cap: 0 }}fn grow(&mut self) {unsafe {let align = mem::align_of::<T>();let elem_size = mem::size_of::<T>();let layout: Layout;let (new_cap, ptr) = if self.cap == 0 {layout = Layout::from_size_align_unchecked(elem_size, align);let ptr = alloc(layout);(1, ptr)} else {let new_cap = self.cap * 2;let old_num_bytes = self.cap * elem_size;assert!(old_num_bytes <= (isize::MAX as usize) / 2,"capacity overflow");let new_num_bytes = old_num_bytes * 2;layout = Layout::from_size_align_unchecked(new_num_bytes, align);let ptr = realloc(self.ptr.as_ptr() as *mut _,layout,new_num_bytes);(new_cap, ptr)};if ptr.is_null() { handle_alloc_error(layout); }if let Some(ptr) = Unique::new(ptr as *mut _) {self.ptr = ptr;} else {panic!("error!");}self.cap = new_cap;}}
}fn main() {println!("Hello, world!");
}

027 Rust死灵书之Vec内存分配相关推荐

  1. 035 Rust死灵书之Vec处理零尺寸类型

    介绍 本系列录制的视频主要放在B站上Rust死灵书学习视频 Rust 死灵书相关的源码资料在https://github.com/anonymousGiga/Rustonomicon-Source 详 ...

  2. 032 Rust死灵书之Vec的IntoIter

    介绍 本系列录制的视频主要放在B站上Rust死灵书学习视频 Rust 死灵书相关的源码资料在https://github.com/anonymousGiga/Rustonomicon-Source 详 ...

  3. 029 Rust死灵书之Vec实现Drop

    介绍 本系列录制的视频主要放在B站上Rust死灵书学习视频 Rust 死灵书相关的源码资料在https://github.com/anonymousGiga/Rustonomicon-Source 详 ...

  4. 036 Rust死灵书之Vec的完整代码测试

    介绍 本系列录制的视频主要放在B站上Rust死灵书学习视频 Rust 死灵书相关的源码资料在https://github.com/anonymousGiga/Rustonomicon-Source 详 ...

  5. 028 Rust死灵书之Vec的push和pop

    介绍 本系列录制的视频主要放在B站上Rust死灵书学习视频 Rust 死灵书相关的源码资料在https://github.com/anonymousGiga/Rustonomicon-Source V ...

  6. 031 Rust死灵书之Vec实现insert和remove

    介绍 本系列录制的视频主要放在B站上Rust死灵书学习视频 Rust 死灵书相关的源码资料在https://github.com/anonymousGiga/Rustonomicon-Source 详 ...

  7. 016 Rust死灵书之安全方式内存初始化

    本系列录制的视频主要放在B站上Rust死灵书学习视频 Rust 死灵书相关的源码资料在https://github.com/anonymousGiga/Rustonomicon-Source 介绍 所 ...

  8. 033 Rust死灵书之重构Vec

    介绍 本系列录制的视频主要放在B站上Rust死灵书学习视频 Rust 死灵书相关的源码资料在https://github.com/anonymousGiga/Rustonomicon-Source 详 ...

  9. 030 Rust死灵书之让Vec支持slice

    介绍 本系列录制的视频主要放在B站上Rust死灵书学习视频 Rust 死灵书相关的源码资料在https://github.com/anonymousGiga/Rustonomicon-Source 详 ...

最新文章

  1. 如何防止批处理文件执行后自动关闭控制台
  2. log4net简介(三)之无法写入日志
  3. java adt mac_Mac下搭建Eclipse Android开发环境
  4. 解读阿里巴巴集团的“大中台、小前台”组织战略
  5. 到天宫做客(洛谷P1178题题解,Java语言描述)
  6. js,在字符串中,查找某个字符的位置
  7. 机器学习速成课程 | 练习 | Google Development——编程练习:稀疏性和 L1 正则化
  8. Python学习笔记10:内建结构
  9. Dgraph安装以及使用1
  10. 啊哈C语言 第8章 游戏时间到了(第29讲)
  11. 《神经科学:探索脑》学习笔记(合集)
  12. 华为交换机 查ip冲突_华为交换机如何查看本交换机IP地址?
  13. 【学习方法】 高效记忆秘籍,背书轻松开挂!3个方法专治记不住忘得快,让你像喝水一样高效学习!
  14. zabbix-server仪表板出现: 不
  15. Shell脚本速查手册
  16. 敏捷开发绩效管理之四:为团队设立外部绩效目标(目标管理,外向型绩效)
  17. 2013-8-17 上周工作总结
  18. Zhong__Docker安装和简单使用
  19. 简单使用vue拖拽组件vue3-dnd
  20. 无法访问 F:\。文件或目录损坏且无法读取。

热门文章

  1. 设计一个程序,在顺序表中采用分块查找发查找关键字。
  2. LeetCode刷题之路(四)——medium的进阶
  3. 用python批量把DICOM(dcm)转换成jpg图像
  4. FAST AND HIGH-QUALITY SINGING VOICE SYNTHESIS SYSTEM BASED ON CONVOLUTIONAL NEURAL NETWORKS
  5. ArrayIndexOutOfBoundsException数组下标越界异常的解决过程
  6. Clickhouse 在云原生场景下的部署和使用
  7. 什么是推荐系统与常见的推荐系统评价指标
  8. 【音频处理】乐器音符播放时电流处理 ( 使用均衡器调节低频 )
  9. 2019最新Android常用开源库总结(持续更新,建议收藏)
  10. 《Java 2 实用教程》课程学习(17)——《Java 程序设计》实验指导书-校内实验教材