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),
    ];
}
相关推荐
掘金安东尼10 分钟前
前端周刊第421期(2025年7月1日–7月6日)
前端·面试·github
摸鱼仙人~12 分钟前
深入理解 classnames:React 动态类名管理的最佳实践
前端·react.js·前端框架
未来之窗软件服务15 分钟前
chrome webdrive异常处理-session not created falled opening key——仙盟创梦IDE
前端·人工智能·chrome·仙盟创梦ide·东方仙盟·数据调式
kymjs张涛15 分钟前
零一开源|前沿技术周报 #6
前端·ios·harmonyos
玲小珑18 分钟前
Next.js 教程系列(十)getStaticPaths 与动态路由的静态生成
前端·next.js
天天鸭24 分钟前
写个vite插件自动处理系统权限,降低99%重复工作
前端·javascript·vite
蓝婷儿29 分钟前
每天一个前端小知识 Day 23 - PWA 渐进式 Web 应用开发
前端
无奈何杨38 分钟前
CoolGuard风控中新增移动距离和移动速度指标
前端·后端
恋猫de小郭1 小时前
Google I/O Extended :2025 Flutter 的现状与未来
android·前端·flutter
江城开朗的豌豆1 小时前
Vue-router方法大全:让页面跳转随心所欲!
前端·javascript·vue.js