24_vector

1. 概述

Vector,叫做Vector,又一个标准库提供,可存储多个值,只能存储相同的数据类型,这些值在内存中连续存放。

使用Vec::new创建Vector,如下示例代码

Rust 复制代码
fn main() {
    let v: Vec<i32> = Vec::new();
}

也可以使用初始值创建Vec<T>,使用vec!宏,如下示例代码

Rust 复制代码
fn main() {
    let v = vec![1, 2, 3];
}

2. 更新vector

可以使用push方法添加元素,如下示例代码

Rust 复制代码
fn main() {
    let mut v = Vec::new();
    v.push(1);
    v.push(2);
    v.push(3);
}

3. 读取vector的元素

两种方式可以引用vector里的值,索引、get方法,如下示例代码

rust 复制代码
fn main() {
    let v = vec![1, 2, 3, 4, 5];
    let third: &i32 = &v[2];
    println!("The third element is {}", third);

    match v.get(2) {
        Some(third) => println!("The third element id {}", third);

        None => println!("There is no third element");
    }
}

遍历vector

Rust 复制代码
fn main() {
    let v = vec![100, 32, 57];
    for i in &v {
        println!("{}", i);
    }
}

我们还可以在编译的过程中修改vector元素的值

Rust 复制代码
fn main() {
    let mut v = vec![100, 32, 57];
    for i in &mut v {
        *i += 50;
    }

    for i in v {
        println!("{}", i);
    }
}

4. 删除vector

与其他元素struct一样,当vector离开作用域后,它就被清理掉,它所有的元素也被清理掉。

5. 所有权和借用规则

不能在同一作用域内同时拥有可变和不可变引用。如下示例代码

rust 复制代码
fn main() {
    // 声明了一个可变的vec
    let mut v = vec![1, 2, 3, 4, 5];
    // 引用了一个不可变的借用
    let first = &v[0];
    // 又向v中添加值,这里发生了可变的借用,将导致报错
    v.push(6);
    println!("The first element is {}", first);
}

6. vector 和 enum

在vector里只能存放相同的数据,当我们需要存储不同的数据时。这时候我们就使用使用enum加上vector来存储数据。enum的变体可以附加不同类型的数据,enum的变体定义在同一个enum类型下。示例代码如下

rust 复制代码
enum SpreadsheetCell {
    Int(i32),
    Float(f64),
    Text(String)
}

fn main() {
    let row = vec![
        SpreadsheetCell::Int(3),
        SpreadsheetCell::Text(String::from("blue")),
        SpreadsheetCell::Float(12.12),
    ];
}
相关推荐
草字18 小时前
css 按钮的脉冲光环动画,强调动画。
前端·css
BD_Marathon18 小时前
【JavaWeb】CSS_三大选择器
前端·css
jump68018 小时前
柯里化
前端
NeoInfra18 小时前
全面解读ThinkPHP 5.0:现代PHP框架的架构演进与安全实践
前端
一 乐18 小时前
宠物店管理|基于Java+vue的宠物猫店管理管理系统(源码+数据库+文档)
java·开发语言·前端·数据库·vue.js·spring boot·后端
qq_2290580118 小时前
react的3中请求
前端·react.js·前端框架
渴望成为python大神的前端小菜鸟18 小时前
VUE 面试题
前端·javascript·vue.js·面试题
想要成为糕糕手18 小时前
深入理解 JavaScript 中的 “this”:从自由变量到绑定规则
前端·javascript
北极象18 小时前
Electron + Playwright 一文多发应用架构设计
前端·javascript·electron
咖猫18 小时前
guacamole-web 1.5.5 index.html
前端·javascript·html