5

使用 MIT-Scheme 9.x,有没有办法使用调试器或其他工具来检查匿名复合过程(通过返回 lambda 函数创建),例如找出它来自哪一行的确切代码?

例如,我目前正在做类似的事情:

(foo 2 3)

我看到一条错误消息,例如:

;The procedure #[compound-procedure 65] has been called with 2 arguments; it requires exactly 0 arguments.

... foo 正在做一些进一步的调度( foo 不是这里的问题,它更深)。在这个例子中,我真的很想知道 #[compound-procedure 65] 的内部结构,因为它显然不是我所期望的。那里的 Lisp/Scheme 向导是否知道获取这些详细信息的方法?谢谢。

4

1 回答 1

7

本页描述了一些有趣的调试工具:调试辅助工具

从我尝试的简短实验中,我认为您可以使用该pp函数来检查复合过程对象的来源:

1 ]=> (define (sum-squares x y) (+ (* x x) (* y y)))

;Value: sum-squares

1 ]=> (sum-squares 3)

;The procedure #[compound-procedure 13 sum-squares]
;has been called with 1 argument
;it requires exactly 2 arguments.
;To continue, call RESTART with an option number:
; (RESTART 1) => Return to read-eval-print level 1.

2 error> (pp #[compound-procedure 13 sum-squares])
(named-lambda (sum-squares x y)
  (+ (* x x) (* y y)))
;Unspecified return value

2 error> 

看来你甚至可以得到lambda函数和编译函数的来源:

1 ]=> (define (make-acc-gen n) (lambda (i) (set! n (+ n i)) n))

;Value: make-acc-gen

1 ]=> (pp (make-acc-gen 0))
(lambda (i)
  (set! n (+ n i))
  n)
;Unspecified return value

1 ]=> display

;Value 15: #[compiled-procedure 15 ("output" #x16) #x1a #x101b23bd2]

1 ]=> (pp  #[compiled-procedure 15 ("output" #x16) #x1a #x101b23bd2])
(named-lambda (display object #!optional port environment)
  (let ((port (optional-output-port port 'display)))
    (unparse-object/top-level object port #f environment)
    ((%record-ref (%record-ref port 1) 14) port)))
;Unspecified return value

1 ]=> 

链接页面上还有一些其他有趣的反射工具。麻省理工学院方案也有一堆东西可以作为一流的对象来处理环境,这对于某些调试任务很有用。希望有帮助!

于 2012-01-11T18:28:16.683 回答