Rust在线运行

版本:

所属目录
点击了解高性能代码运行API
运行结果
教程手册
代码仓库
极速运行
终端运行
图形+终端

                        
以下是用户最新保存的代码
## 输入三个整数x,y,z,请把这三个数由小到大输出。 发布于:2024-03-03 11:45 # rust slice 发布于:2024-02-20 13:49 rust学习 发布于:2024-01-04 08:20 Rust hello world 发布于:2024-01-01 23:49 # Rust的常用迭代器适配器 ## map 可以用闭包将迭代器里的每个元素应用闭包里自定义的逻辑,从而生成处理后的元素迭代器,可以应用于数据处理与提取. ## filter 可以使用闭包过滤迭代器里的元素,只挑选出符合要求的元素组成新的迭代器返回。 ## fold ## zip ## chunks ## Chain ## all ## any ## windows ## cycle 发布于:2023-12-27 17:58 # 箱子、栈和堆 在 Rust 中,所有值默认都是栈分配的。通过创建 Box<T>,可以把值装箱(boxed)来使它在堆上分配。箱子(box,即 Box<T> 类型的实例)是一个智能指针,指向堆分配的 T 类型的值。当箱子离开作用域时,它的析构函数会被调用,内部的对象会被销毁,堆上分配的内存也会被释放。 被装箱的值可以使用 * 运算符进行解引用;这会移除掉一层装箱。 发布于:2023-12-27 17:40 测试rust的值域安全性 发布于:2023-12-12 09:52 书本的内容 发布于:2023-11-17 17:25 rust代码测试 发布于:2023-11-14 13:41 Learn Rust 发布于:2023-11-09 17:33 Rust学习使用 发布于:2023-05-21 11:21 exercise trait 发布于:2023-04-16 19:42 闭包的捕获 发布于:2023-01-28 16:32 Rust 结构体相关代价 发布于:2022-12-29 09:22 [package] name = "hello_rust" version = "0.1.0" authors = ["gress"] edition = "2018" [dependencies] anyhow= “0.1” 发布于:2022-12-06 20:09 第一个Rust程序 发布于:2022-06-20 00:11 开始学习rust 发布于:2022-05-30 13:51 enum sample 发布于:2022-02-24 15:03 泛型、特性与生命周期协同作战里的实例如何使用 发布于:2022-01-02 16:25 Rust第四章---所有权 发布于:2021-12-31 15:31 Rust第三章-常见编程概念 发布于:2021-12-31 13:16 Hello World Rust 发布于:2021-02-11 19:18 [更多]
显示目录

文件与 IO



学习嵌入式的绝佳套件,esp8266开源小电视成品,比自己去买开发板+屏幕还要便宜,省去了焊接不当搞坏的风险。 蜂鸣版+触控升级仅36元,更强的硬件、价格全网最低。

点击购买 固件广场

Rust 文件与 IO

本章介绍 Rust 语言的 I/O 操作。

接收命令行参数

命令行程序是计算机程序最基础的存在形式,几乎所有的操作系统都支持命令行程序并将可视化程序的运行基于命令行机制。

命令行程序必须能够接收来自命令行环境的参数,这些参数往往在一条命令行的命令之后以空格符分隔。

在很多语言中(如 Java 和 C/C++)环境参数是以主函数的参数(常常是一个字符串数组)传递给程序的,但在 Rust 中主函数是个无参函数,环境参数需要开发者通过 std::env 模块取出,过程十分简单:

实例

fn main() {  
    let args \= std::env::args();  
    println!("{:?}", args);  
}

现在直接运行程序:

Args  { inner:  \["D:\\\\rust\\\\greeting\\\\target\\\\debug\\\\greeting.exe"\]  }

也许你得到的结果比这个要长的多,这很正常,这个结果中 Args 结构体中有一个 inner 数组,只包含唯一的字符串,代表了当前运行的程序所在的位置。

但这个数据结构令人难以理解,没关系,我们可以简单地遍历它:

实例

fn main() {  
    let args \= std::env::args();  
    for arg in args {  
        println!("{}", arg);  
    }  
}

运行结果:

D:\\rust\\greeting\\target\\debug\\greeting.exe

一般参数们就是用来被遍历的,不是吗。

现在我们打开许久未碰的 launch.json ,找到 "args": [],这里可以设置运行时的参数,我们将它写成 "args": ["first", "second"] ,然后保存、再次运行刚才的程序,运行结果:

D:\\rust\\greeting\\target\\debug\\greeting.exe
first
second

作为一个真正的命令行程序,我们从未真正使用过它,作为语言教程不在此叙述如何用命令行运行 Rust 程序。但如果你是个训练有素的开发者,你应该可以找到可执行文件的位置,你可以尝试进入目录并使用命令行命令来测试程序接收命令行环境参数。

命令行输入

早期的章节详细讲述了如何使用命令行输出,这是由于语言学习的需要,没有输出是无法调试程序的。但从命令行获取输入的信息对于一个命令行程序来说依然是相当重要的。

在 Rust 中,std::io 模块提供了标准输入(可认为是命令行输入)的相关功能:

实例

use std::io::stdin;  

fn main() {  
let mut str\_buf \= String::new();  

    stdin().read\_line(&mut str\_buf)  
        .expect("Failed to read line.");  

    println!("Your input line is \\n{}", str\_buf);  
}

令 VSCode 环境支持命令行输入是一个非常繁琐的事情,牵扯到跨平台的问题和不可调试的问题,所以我们直接在 VSCode 终端中运行程序。在命令行中运行:

D:\\rust\\greeting\> cd ./target/debug
D:\\rust\\greeting\\target\\debug\>  ./greeting.exe
RUNOOB Your input line is RUNOOB

std::io::Stdio 包含 read_line 读取方法,可以读取一行字符串到缓冲区,返回值都是 Result 枚举类,用于传递读取中出现的错误,所以常用 expect 或 unwrap 函数来处理错误。

注意:目前 Rust 标准库还没有提供直接从命令行读取数字或格式化数据的方法,我们可以读取一行字符串并使用字符串识别函数处理数据。

文件读取

我们在计算机的 D:\ 目录下建立文件 text.txt,内容如下:

This  is a text file.

这是一个将文本文件内容读入字符串的程序:

实例

use std::fs;  

fn main() {  
    let text \= fs::read\_to\_string("D:\\\\text.txt").unwrap();  
    println!("{}", text);  
}

运行结果:

This  is a text file.

在 Rust 中读取内存可容纳的一整个文件是一件极度简单的事情,std::fs 模块中的 read_to_string 方法可以轻松完成文本文件的读取。

但如果要读取的文件是二进制文件,我们可以用 std::fs::read 函数读取 u8 类型集合:

实例

use std::fs;  

fn main() {  
    let content \= fs::read("D:\\\\text.txt").unwrap();  
    println!("{:?}", content);  
}

运行结果:

\[84,  104,  105,  115,  32,  105,  115,  32,  97,  32,  
116,  101,  120,  116,  32,  102,  105,  108,  101,  46\]

以上两种方式是一次性读取,十分适合 Web 应用的开发。但是对于一些底层程序来说,传统的按流读取的方式依然是无法被取代的,因为更多情况下文件的大小可能远超内存容量。

Rust 中的文件流读取方式:

实例

use std::io::prelude::\*;  
use std::fs;  

fn main() {  
    let mut buffer \= \[0u8; 5\];  
    let mut file \= fs::File::open("D:\\\\text.txt").unwrap();  
    file.read(&mut buffer).unwrap();  
    println!("{:?}", buffer);  
    file.read(&mut buffer).unwrap();  
    println!("{:?}", buffer);  
}

运行结果:

\[84,  104,  105,  115,  32\]  \[105,  115,  32,  97,  32\]

std::fs 模块中的 File 类是描述文件的类,可以用于打开文件,再打开文件之后,我们可以使用 File 的 read 方法按流读取文件的下面一些字节到缓冲区(缓冲区是一个 u8 数组),读取的字节数等于缓冲区的长度。

注意:VSCode 目前还不具备自动添加标准库引用的功能,所以有时出现"函数或方法不存在"一样的错误有可能是标准库引用的问题。我们可以查看标准库的注释文档(鼠标放到上面会出现)来手动添加标准库。

std::fs::File 的 open 方法是"只读"打开文件,并且没有配套的 close 方法,因为 Rust 编译器可以在文件不再被使用时自动关闭文件。

文件写入

文件写入分为一次性写入和流式写入。流式写入需要打开文件,打开方式有"新建"(create)和"追加"(append)两种。

一次性写入:

实例

use std::fs;  

fn main() {  
    fs::write("D:\\\\text.txt", "FROM RUST PROGRAM")  
        .unwrap();  
}

这和一次性读取一样简单方便。执行程序之后, D:\text.txt 文件的内容将会被重写为 FROM RUST PROGRAM 。所以,一次性写入请谨慎使用!因为它会直接删除文件内容(无论文件多么大)。如果文件不存在就会创建文件。

如果想使用流的方式写入文件内容,可以使用 std::fs::File 的 create 方法:

实例

use std::io::prelude::\*;  
use std::fs::File;  

fn main() {  
    let mut file \= File::create("D:\\\\text.txt").unwrap();  
    file.write(b"FROM RUST PROGRAM").unwrap();  
}

这段程序与上一个程序等价。

注意:打开的文件一定存放在可变的变量中才能使用 File 的方法!

File 类中不存在 append 静态方法,但是我们可以使用 OpenOptions 来实现用特定方法打开文件:

实例

use std::io::prelude::\*;  
use std::fs::OpenOptions;  

fn main() \-> std::io::Result<()\> {  

    let mut file \= OpenOptions::new()  
            .append(true).open("D:\\\\text.txt")?;  

    file.write(b" APPEND WORD")?;  

    Ok(())  
}

运行之后,D:\text.txt 文件内容将变成:

FROM RUST PROGRAM APPEND WORD

OpenOptions 是一个灵活的打开文件的方法,它可以设置打开权限,除append 权限以外还有 read 权限和 write 权限,如果我们想以读写权限打开一个文件可以这样写:

实例


use std::io::prelude::\*;  
use std::fs::OpenOptions;  

fn main() \-> std::io::Result<()\> {  

    let mut file \= OpenOptions::new()  
            .read(true).write(true).open("D:\\\\text.txt")?;  

    file.write(b"COVER")?;  

    Ok(())  
}

运行之后,D:\text.txt 文件内容将变成:

COVERRUST PROGRAM APPEND WORD
由JSRUN为你提供的Rust在线运行、在线编译工具
        JSRUN提供的Rust 在线运行,Rust 在线运行工具,基于linux操作系统环境提供线上编译和线上运行,具有运行快速,运行结果与常用开发、生产环境保持一致的特点。
yout