阶乘if语句期望'()'找到整数

我是 rust 的新手(来自 c/c++ 和 python 编程)所以为了学习我正在编写一些基本函数。下面我有一个阶乘函数,它接受一个有符号整数,并且有两个 if 检查它。

fn factorial(x: i32) -> i32 {
    let result = if x > 1 {
        x * factorial(x-1)
    } else if x <= 1 {
        1
    };

    result
}

据我所知,if 和 else-if 块应该处理它的所有情况。但是,在编译时会引发以下错误:

error[E0317]: `if` may be missing an `else` clause
  --> src/main.rs:22:12
   |
22 |       } else if x <= 1 {
   |  ____________^
23 | |         1
   | |         - found here
24 | |     };
   | |_____^ expected `()`, found integer
   |
   = note: `if` expressions without `else` evaluate to `()`
   = help: consider adding an `else` block that evaluates to the expected type

error: aborting due to previous error

For more information about this error, try `rustc --explain E0317`.
error: could not compile `functions`

如果我用 else 替换 else-if,它编译得很好。为什么我需要用 else 替换它?前面的 else-if 不应该足够好吗?

回答

正如错误消息所说,如果if表达式没有,则表达式else的类型为()。这是因为表达式只能有一种类型,并且在一般情况下没有合理的默认值,如果条件计算为false- 这else就是 for!

在您的情况下,编译器可能已经发现这两个谓词实际上是详尽无遗的。事实并非如此,事实就是如此。如果编译器在这种情况下可以检测到穷举性,那么在其他“明显”情况下也不能检测到它会很奇怪。但是谓词可以是任意表达式,在一般情况下不可能实现检查。

在此示例中,编译器必须分析random函数体以了解谓词是否详尽:

// random(x) might return a different value each time it's called
if random(x) > 1 {
    1
} else if random(x) <= 1 {
    2
} // Not exhaustive!

保持一致似乎是该语言的最佳选择,因为您始终可以else在末尾添加一个。


以上是阶乘if语句期望'()'找到整数的全部内容。
THE END
分享
二维码
< <上一篇
下一篇>>