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),
    ];
}
相关推荐
excel2 分钟前
Vue SFC 编译核心解析(第 3 篇)——绑定分析与作用域推断
前端
excel3 分钟前
Vue SFC 编译核心解析(第 4 篇)——普通 <script> 与 <script setup> 的合并逻辑
前端
excel4 分钟前
Vue SFC 编译核心解析(第 1 篇)——compileScript 总体流程概览
前端
excel5 分钟前
Vue 编译器中的 processAwait 实现深度解析
前端
excel9 分钟前
Vue SFC 编译核心解析(第 2 篇)——宏函数解析机制
前端
星释13 分钟前
Rust 练习册 :Matching Brackets与栈数据结构
数据结构·算法·rust
excel16 分钟前
🔍 Vue 模板编译中的资源路径转换机制:transformAssetUrl 深度解析
前端
excel18 分钟前
Vue 模板编译中的 srcset 机制详解:从 HTML 语义到编译器实现
前端
excel18 分钟前
🌐 从 Map 到 LRUCache:构建智能缓存工厂函数
前端
星释19 分钟前
Rust 练习册 :Luhn与校验算法
java·算法·rust