Rust猜数字游戏

Rust进阶:猜数字游戏

Rust是一门现代的系统级编程语言,注重内存安全、并发性能以及表达力。在这篇博客中,我们将深入介绍一个更加复杂的猜数字游戏代码,展示Rust语言的一些高级特性。

代码示例

以下是一个升级版的Rust猜数字游戏代码:

rust 复制代码
use std::io;
use std::cmp::Ordering;
use rand::Rng;

fn main() {
    println!("猜数字!");
    // 生成一个1到100之间的随机数
    let secret_number = rand::thread_rng().gen_range(1..101);
    //println!("神秘数字:{}", secret_number);

    // 游戏主循环
    loop {
        println!("猜测一个数");
        let mut guess = String::new();

        io::stdin().read_line(&mut guess).expect("无法读取行");

        // 使用类型遮蔽(Shadowing)实现类型转换
        let guess: u32 = match guess.trim().parse() {
            Ok(num) => num,
            Err(_) => continue,
        };

        // 使用模式匹配比较猜测的数字和神秘数字
        match guess.cmp(&secret_number) {
            Ordering::Less => println!("太小了!"),
            Ordering::Greater => println!("太大了!"),
            Ordering::Equal => {
                println!("恭喜你,猜对了!");
                break;
            }
        }
    }
}

代码解析

这个升级版的猜数字游戏引入了一些新的概念和库:

  1. use std::cmp::Ordering;:导入Ordering枚举,用于比较两个值的大小关系。

  2. use rand::Rng;:导入rand库中的Rng trait,用于生成随机数。

  3. let secret_number = rand::thread_rng().gen_range(1..101);:使用rand库生成一个1到100之间的随机数,作为神秘数字。

  4. match guess.cmp(&secret_number) { ... }:使用match表达式和cmp方法比较猜测的数字和神秘数字,根据大小关系输出相应提示。

  5. loop { ... }:引入一个无限循环,直到玩家猜对为止。

  6. 使用类型遮蔽(Shadowing):在原有变量guess上重新声明,进行类型转换。这允许我们保持可变性并改变变量的类型。

运行代码

要运行这个升级版的猜数字游戏,同样保存到一个.rs文件(例如advanced_guess_number.rs)中,然后执行:

bash 复制代码
$ rustc advanced_guess_number.rs
$ ./advanced_guess_number

现在,您将体验到一个更加交互和有趣的猜数字游戏,体现了Rust语言的强大和灵活性。

总的来说,这个博客通过猜数字游戏代码的逐步升级,展示了Rust语言的一些高级特性,如模式匹配、trait使用和库的集成。希望这能够帮助您更深入地理解和学习Rust编程。

相关推荐
gregmankiw10 分钟前
C#调用Rust动态链接库DLL的案例
开发语言·rust·c#
music&movie41 分钟前
算法工程师认知水平要求总结
人工智能·算法
@一枝梅44 分钟前
vue3 vite.config.js 引入bem.scss文件报错
javascript·rust·vue·scss
laocui11 小时前
Σ∆ 数字滤波
人工智能·算法
yzx9910132 小时前
Linux 系统中的算法技巧与性能优化
linux·算法·性能优化
全栈凯哥2 小时前
Java详解LeetCode 热题 100(26):LeetCode 142. 环形链表 II(Linked List Cycle II)详解
java·算法·leetcode·链表
全栈凯哥2 小时前
Java详解LeetCode 热题 100(27):LeetCode 21. 合并两个有序链表(Merge Two Sorted Lists)详解
java·算法·leetcode·链表
SuperCandyXu2 小时前
leetcode2368. 受限条件下可到达节点的数目-medium
数据结构·c++·算法·leetcode
Humbunklung3 小时前
机器学习算法分类
算法·机器学习·分类
Ai多利3 小时前
深度学习登上Nature子刊!特征选择创新思路
人工智能·算法·计算机视觉·多模态·特征选择