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),
    ];
}
相关推荐
brzhang5 分钟前
别再梭哈 Curosr 了!这 AI 神器直接把需求、架构、任务一条龙全干了!
前端·后端·架构
Kagol14 分钟前
TinyEditor v4.0 alpha 版本发布,更强大的表格、更丰富的表情、体验更好的图片/视频/文件上传功能
前端·开源
然我23 分钟前
路由还能这么玩?从懒加载到路由守卫,手把手带你解锁 React Router 进阶技巧
前端·react.js·面试
良木林1 小时前
JavaScript书写基础和基本数据类型
开发语言·前端·javascript
brzhang8 小时前
我操,终于有人把 AI 大佬们 PUA 程序员的套路给讲明白了!
前端·后端·架构
止观止8 小时前
React虚拟DOM的进化之路
前端·react.js·前端框架·reactjs·react
goms9 小时前
前端项目集成lint-staged
前端·vue·lint-staged
谢尔登9 小时前
【React Natve】NetworkError 和 TouchableOpacity 组件
前端·react.js·前端框架
Lin Hsüeh-ch'in9 小时前
如何彻底禁用 Chrome 自动更新
前端·chrome
augenstern41611 小时前
HTML面试题
前端·html