标准ML例外

时间:2013-08-04 19:31:25

标签: exception standards sml ml

我有以下代码:

 - 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;

2 个答案:

答案 0 :(得分:4)

raisehandle的优先级在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