Rust那些事之Vector妙用

开发 前端
在 vector 的结尾增加新元素时,在没有足够空间将所有元素依次相邻存放的情况下,可能会要求分配新内存并将老的元素拷贝到新的空间中。这时,第一个元素的引用就指向了被释放的内存。借用规则阻止程序陷入这种状况。

​导语

我们知道vector是一个动态数组,在C++中来说,vector中存储的只能是一种类型,那如何做到存储多个,无非就是包一层,例如:结构体、void*。而在Rust中enum非常独特,每个值可以是不同类型,因此我们从enum来考虑。另一方面,几种不同的方式从vector中读取有何不同呢?

1.vector实例

例如:一个enum包含了不同类型

#[derive(Debug)]
enum Spec {
Int(i32),
Float(f64),
Bool(bool),
Text(String),
}

调用:

pub fn mult_type()  {
let r = vec![Spec::Int(1), Spec::Float(2.2), Spec::Bool(true), Spec::Text(String::from("hello"))];
println!("{:?}", r)
}

这样便可以简单的完成一个vector使用不同类型。

2.&实例

vector中,你可以取其中的元素,有下面几个方法:

v[2]
&v[2]
v.get(2)

这三个有什么区别?

前两个很明显,跟传统的获取元素一致,如果下标越界,便会panic,而get使用了Option<T>特殊枚举,在越界情况下会返回None,不会panic,足以说明Rust的安全性。

因为v.get返回的是Option,我们可以使用match控制流,提取出包裹的内容。

match v.get(2) {
Some(x) => println!("{}", x),
None => println!("None")
}

接下来,我们考虑v[2]与&v[2]的区别。

// case1: &
let mut v = vec![1, 2, 3, 4, 5];
let first = &v[0];
v.push(6);
println!("The first element is: {}", first);

// case2: plain
let mut v = vec![1, 2, 3, 4, 5];
let first = v[0];
v.push(6);
println!("The first element is: {}", first);

考虑上述两个case,在push的时候哪个case是正常的?

答案是第二个case会正常运行,第一个case由于&的影响,会报错。

在 vector 的结尾增加新元素时,在没有足够空间将所有元素依次相邻存放的情况下,可能会要求分配新内存并将老的元素拷贝到新的空间中。这时,第一个元素的引用就指向了被释放的内存。借用规则阻止程序陷入这种状况。

此时便会报错:error: cannot borrow v as mutable because it is also borrowed as immutable。

责任编辑:武晓燕 来源: 光城
相关推荐

2021-07-27 10:52:27

iOS WKWebView容器

2012-05-01 08:06:49

手机

2011-05-19 16:47:50

软件测试

2017-05-15 21:50:54

Linux引号

2024-02-04 17:03:30

2017-04-06 09:35:10

大数据SparkSQLSpark

2014-06-06 16:08:17

初志科技

2015-05-28 14:02:09

JavaJava日志性

2011-12-02 10:32:23

Java

2020-09-23 09:07:16

特权账号管理PAM网络安全

2021-10-19 21:39:51

Unsafe构造器内存

2011-08-22 16:42:43

SqliteiPad

2012-01-02 19:30:22

iPad

2011-09-19 15:40:35

2011-07-04 15:30:24

Qt 布局 GridLayout

2015-09-14 09:16:17

iOS统计打点

2020-07-29 08:14:59

云计算云迁移IT

2011-06-30 14:34:17

QT Tablewidge QTableWidg

2009-07-29 10:36:04

北电收购

2010-07-26 11:02:19

Perl模式匹配
点赞
收藏

51CTO技术栈公众号