我有以下代码:
- exception Negative of string;
> exn Negative = fn : string -> exn
- local fun fact 0 =1
| fact n = n* fact(n-1)
in
fun factorial n=
if n >= 0 then fact n
else
raise Negative "Insert a positive number!!!"
handle Negative msg => 0
end;
有什么问题?我收到错误:
! Toplevel input:
! handle Negative msg => 0
! ^
! Type clash: expression of type
! int
! cannot have type
! exn
我该如何解决?如果用户输入负数,我希望函数通过例外返回0。
我也想知道当用户输入负数时如何显示消息,因为print()返回单位,但函数的其余部分返回int;
答案 0 :(得分:4)
raise
和handle
的优先级在SML中有点奇怪。你写的小组是什么
raise ((Negative "...") handle Negative msg => 0)
因此,您需要在if
周围添加括号以获得正确的含义。
另一方面,我不明白为什么你提出异常只是为了立即抓住它。为什么不简单地在else
分支中返回0?
编辑:如果要打印某些内容然后返回结果,请使用分号运算符:
(print "error"; 0)
但是,我强烈建议不要在阶乘函数中这样做。最好将I / O和错误处理与基本计算逻辑分开。
答案 1 :(得分:1)
您可以通过多种方式修复代码:
local
fun fact 0 = 1
| fact n = n * fact (n-1)
in
(* By using the built-in exception Domain *)
fun factorial n =
if n < 0 then raise Domain else fact n
(* Or by defining factorial for negative input *)
fun factorial n =
if n < 0 then -1 * fact (-n) else fact n
(* Or by extending the type for "no result" *)
fun factorial n =
if n < 0 then NONE else SOME (fact n)
end