锈教科书的猜谜游戏扩展显示出奇怪的行为

时间:2018-11-07 01:54:32

标签: rust

因此,我将猜谜游戏扩展为基本上询问用户是否要再次玩。如果他们输入y,则程序将返回主游戏循环;如果他们输入n,则其将跳出当前循环,然后程序结束。如果他们输入其他任何内容,则理论上它应该只跳到play_again循环的顶部,并像玩家接下来输入的内容一样重新分配yae_or_nay变量。但是它没有这样做,或者至少看起来像是错误地覆盖了它。我是否错误地重新分配了变量?此处是代码(请注意,该程序的前半部分与教科书中的代码几乎相同,但是由于该程序太短了,所以我决定包括全部内容):

extern crate rand;

use std::io;
use std::cmp::Ordering;
use rand::Rng; // random number generation library from rand 

fn main() {
println!("Guessing game!\n");

let mut answer = rand::thread_rng().gen_range(1,101); 
'gameloop: loop {
    println!("Please print your guess:");

    let mut yae_or_nay = String::new();
    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(_) => {
            println!("Not a number!");
            continue;
        }
    };

    match guess.cmp(&answer) {
        Ordering::Less => println!("Higher!"),
        Ordering::Greater => println!("Lower!"),
        Ordering::Equal => {
            println!("Correct! Would you like to play again? (y/n)");
            'play_again: loop {
                io::stdin().read_line(&mut yae_or_nay)
                    .expect("Failed to read line.");

                match yae_or_nay.trim() { // match against a string
                    "y" => {
                        answer = rand::thread_rng().gen_range(1,101);
                        println!("Playing again...");
                        continue 'gameloop;
                    },
                    "n" => {
                        println!("Thanks for playing! Exiting now.");
                        break
                    },
                    _ => {
                        println!("what? You entered {}", &yae_or_nay);
                        continue 'play_again
                    }
                };
            }
        }
    }
}
}

这是控制台输出的一小段:

46
Correct! Would you like to play again? (y/n)
i
what? You entered i

y
what? You entered i
y

n
what? You entered i
y
n

 . // period here for formatting sake, not actually in console

如您所见,我的程序重新分配yae_or_nay的方式似乎很奇怪。有人知道发生了什么吗?预先感谢您的帮助。

1 个答案:

答案 0 :(得分:2)

问题是您永远不会清除newnode->next,并且io::stdin().read_line(&mut yae_or_nay)append保留字符串,而不是替换其内容。

  

读取所有字节,直到到达换行符(0xA字节),然后将它们附加到提供的缓冲区中。

要么你应该做

temp->next

在阅读之前,或者最好将声明移至

yae_or_nay