问题描述
#lang racket
(require rackunit racket/exn)
(define (string-last s)
(let ((lng (string-length s)))
(substring s (- lng 1) lng)))
(string-last "")
(check-equal? (string-last "1") "1")
(check-equal? (string-last "testing") "g")
使用空字符串调用字符串last失败,原因是:
--------------------
. ERROR
name: check-exn
location: 014.rkt:12:0
substring: contract violation
expected: exact-nonnegative-integer?
given: -1
argument position: 2nd
other arguments...:
""
0
--------------------
我尝试过
(check-exn exn:fail? (string-last ""))
和其他几个替代exn:fail?
的变体,但我没有找到合适的变体。
解决方法
check-exn
需要一个不带参数的函数-一个thunk-它可以调用这会引发异常。所以正确的咒语是
(check-exn exn:fail? (thunk (string-last "")))
必须传递一个thunk,否则Racket的默认评估顺序将意味着在调用该函数之前 引发该异常,因此它永远无法捕获。