猜数字游戏(2)

Rust创建猜数字游戏

1.构建项目

bash 复制代码
cargo new guessing_game
cd guessing_game

1.测试项目运行

bash 复制代码
cargo run

2.处理一次猜想

rust 复制代码
// io输入/输出库,io库来自于标准库
use rand::Rng;
use std::cmp::Ordering;
use std::io;



fn main() {
    //println!("Guess the number!");

    //rand::thead_rng函数用来提供特定随机数生成器,gen_range方法调用随机数生成器,区间格式采用的是start..end
    //let secret_number = rand::thread_rng().gen_range(1..101);
    //println!("The secret number is: {}",secret_number);

    //println!("Please input your guess.");
    /*
        let apple = 5; // 不可变
        let mut apple = 5;// 可变
        变量默认是不可变的,想要变量可变,可以在变量名强添加mut

        ::语法表明new是string类型的一个关联函数

        关联函数是实现一种特定类型的函数
    
    */
    //let mut guess = String::new();
    /*
        程序开头没使用 use std::io引入io库,也可以通过std::io::stdin来调用函数
        read_line()方法,标准输入句柄中获取用户输入
        &表示这个参数是一个引用,让代码的多个部分可以访问同一个数据,而无需再内存中多次拷贝 
    */
    //io::stdin()
    //.read_line(&mut guess)
    //使用Result类型来处理潜在的错误
    //.expect("Failed to read line");
    //println!("You guessed: {}",guess);

    println!("Guess the number");

    let secret_number = rand::thread_rng().gen_range(1..100);
    loop{
        println!("Please input your  guess!");

        let mut guess = String::new();
        
        io::stdin()
        .read_line(&mut guess)
        .expect("Failed to read line");

        let guess: u32 = match guess.trim().parse() {
            Ok(num) => num,
            Err(_) => continue,
        };
        println!("You guessed:{}",guess);
        match guess.cmp(&secret_number){
            Ordering::Less => println!("Too small"),
            Ordering::Greater => println!("Too big"),
            Ordering::Equal => {
                println!("you win");
                break;
            }
        }
    }
    
}
相关推荐
颜酱9 小时前
图结构完全解析:从基础概念到遍历实现
javascript·后端·算法
Coder_Boy_12 小时前
基于SpringAI的在线考试系统-考试系统开发流程案例
java·数据库·人工智能·spring boot·后端
掘金者阿豪13 小时前
关系数据库迁移的“暗礁”:金仓数据库如何规避数据完整性与一致性风险
后端
ServBay13 小时前
一个下午,一台电脑,终结你 90% 的 Symfony 重复劳动
后端·php·symfony
sino爱学习13 小时前
高性能线程池实践:Dubbo EagerThreadPool 设计与应用
java·后端
颜酱13 小时前
从二叉树到衍生结构:5种高频树结构原理+解析
javascript·后端·算法
掘金者阿豪14 小时前
UUID的隐形成本:一个让数据库“慢下来”的陷阱
后端
用户0844652563714 小时前
Docker 部署 MongoDB Atlas 到服务端
后端
Anita_Sun14 小时前
一看就懂的 Haskell 教程 - 类型推断机制
后端·haskell
Anita_Sun15 小时前
一看就懂的 Haskell 教程 - 类型签名
后端·haskell