- Rust 教程
- 铁锈 - 主页
- Rust - 简介
- Rust - 环境设置
- Rust - HelloWorld 示例
- Rust - 数据类型
- Rust - 变量
- 铁锈 - 恒定
- Rust - 字符串
- Rust - 运算符
- Rust - 决策
- 铁锈 - 循环
- Rust - 函数
- Rust - 元组
- Rust - 数组
- Rust - 所有权
- Rust - 借用
- 铁锈 - 切片
- Rust - 结构
- Rust - 枚举
- Rust - 模块
- Rust - 收藏
- Rust - 错误处理
- Rust - 泛型类型
- Rust - 输入输出
- Rust - 文件输入/输出
- Rust - 包管理器
- Rust - 迭代器和闭包
- Rust - 智能指针
- Rust - 并发
- Rust 有用的资源
- Rust - 快速指南
- Rust - 有用的资源
- Rust - 讨论
Rust - 输入输出
本章讨论如何从标准输入(键盘)接受值并将值显示到标准输出(控制台)。在本章中,我们还将讨论传递命令行参数。
读者和作者类型
Rust 的输入和输出标准库功能围绕两个特征进行组织 -
- 读
- 写
先生编号 | 特征及描述 | 例子 |
---|---|---|
1 | 读 实现 Read 的类型具有面向字节输入的方法。他们被称为读者 | 标准输入、文件 |
2 | 写 实现 Write 的类型支持面向字节和 UTF-8 文本输出。他们被称为作家。 | 标准输出、文件 |
阅读特质
读取器是程序可以从中读取字节的组件。示例包括从键盘、文件等读取输入。此特征的read_line()方法可用于从文件或标准输入流读取数据,一次一行。
先生编号 | 特征 | 方法及说明 |
---|---|---|
1 | 读 | read_line(&mut line)->结果 读取一行文本并将其附加到 line(字符串)。返回值是 io::Result,即读取的字节数。 |
插图 - 从控制台读取 - stdin()
Rust 程序可能必须在运行时接受用户的值。以下示例从标准输入(键盘)读取值并将其打印到控制台。
fn main(){ let mut line = String::new(); println!("Enter your name :"); let b1 = std::io::stdin().read_line(&mut line).unwrap(); println!("Hello , {}", line); println!("no of bytes read , {}", b1); }
stdin ()函数返回当前进程的标准输入流的句柄,可以对其应用read_line函数。当遇到行尾字符时,该函数尝试读取输入缓冲区中存在的所有字符。
输出
Enter your name : Mohtashim Hello , Mohtashim no of bytes read , 10
写特征
写入器是程序可以写入字节的组件。示例包括将值打印到控制台、写入文件等。此特征的 write() 方法可用于将数据写入文件或标准输出流。
先生编号 | 特征 | 方法及说明 |
---|---|---|
1 | 写 | 写入(&buf)->结果 将切片 buf 中的一些字节写入底层流。它返回一个 io::Result,即写入的字节数。 |
插图 - 写入控制台 - stdout()
打印!或打印!宏可用于在控制台上显示文本。但是,您也可以使用write()标准库函数将一些文本显示到标准输出。
让我们考虑一个例子来理解这一点。
use std::io::Write; fn main() { let b1 = std::io::stdout().write("Tutorials ".as_bytes()).unwrap(); let b2 = std::io::stdout().write(String::from("Point").as_bytes()).unwrap(); std::io::stdout().write(format!("\nbytes written {}",(b1+b2)).as_bytes()).unwrap(); }
输出
Tutorials Point bytes written 15
stdout ()标准库函数返回当前进程的标准输出流的句柄,可以对其应用write函数。write() 方法返回一个枚举 Result。unwrap() 是一种从枚举中提取实际结果的辅助方法。如果发生错误,unwrap 方法将发送恐慌。
注意- 文件 IO 将在下一章中讨论。
命令行参数
命令行参数在执行之前传递给程序。它们就像传递给函数的参数。命令行参数可用于将值传递给main()函数。std ::env::args()返回命令行参数。
插图
以下示例将值作为命令行参数传递给 main() 函数。该程序以文件名main.rs创建。
//main.rs fn main(){ let cmd_line = std::env::args(); println!("No of elements in arguments is :{}",cmd_line.len()); //print total number of values passed for arg in cmd_line { println!("[{}]",arg); //print all values passed as commandline arguments } }
程序编译后会生成一个文件main.exe 。多个命令行参数应以空格分隔。从终端以main.exe hello Tutorialspoint 的形式执行 main.exe 。
注意- hello和tutorialspoint是命令行参数。
输出
No of elements in arguments is :3 [main.exe] [hello] [tutorialspoint]
输出显示 3 个参数,因为 main.exe是第一个参数。
插图
以下程序计算作为命令行参数传递的值的总和。由空格分隔的列表整数值被传递给程序。
fn main(){ let cmd_line = std::env::args(); println!("No of elements in arguments is :{}",cmd_line.len()); // total number of elements passed let mut sum = 0; let mut has_read_first_arg = false; //iterate through all the arguments and calculate their sum for arg in cmd_line { if has_read_first_arg { //skip the first argument since it is the exe file name sum += arg.parse::<i32>().unwrap(); } has_read_first_arg = true; // set the flag to true to calculate sum for the subsequent arguments. } println!("sum is {}",sum); }
执行 main.exe 1 2 3 4 程序时,输出将是 -
No of elements in arguments is :5 sum is 10