time-limit.sml

来自「这是我们参加06年全国开源软件的竞赛作品」· SML 代码 · 共 30 行

SML
30
字号
(* time-limit.sml * * COPYRIGHT (c) 1993 by AT&T Bell Laboratories.  See COPYRIGHT file for details. *)structure TimeLimit : sig    exception TimeOut    val timeLimit : Time.time -> ('a -> 'b) -> 'a -> 'b  end = struct    exception TimeOut    fun timeLimit t f x = let	  val setitimer = SMLofNJ.IntervalTimer.setIntTimer	  fun timerOn () = ignore(setitimer (SOME t))	  fun timerOff () = ignore(setitimer NONE)	  val escapeCont = SMLofNJ.Cont.callcc (fn k => (		SMLofNJ.Cont.callcc (fn k' => (SMLofNJ.Cont.throw k k'));		timerOff();		raise TimeOut))	  fun handler _ = escapeCont	  in	    Signals.setHandler (Signals.sigALRM, Signals.HANDLER handler);	    timerOn();	    ((f x) handle ex => (timerOff(); raise ex))	      before timerOff()	  end  end; (* TimeLimit *)

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?