五:控制流.pdfVIP

  1. 1、本文档共16页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
五:控制流

第五章:控制流 2.2 节介绍过 Common Lisp 的求值规则,现在你应该很熟悉了。本章的操作符都有⼀ 个共同 ,就是它们都违反了求值规则。这些操作符让你决定在程序当中何时要求 值。如果普通的函数调⽤是 Lisp 程序的树叶的话,那这些操作符就是连结树叶的树 枝。 5.1 区块 (Blocks) 5.2 语境 (Context) 5.3 条件 (Conditionals) 5.4 迭代 (Iteration) 5.5 多值 (Multiple Values) 5. 中⽌ (Aborts) 5.7 ⽰例:⽇期运算 (Example: Date Arithmetic) Chapter 5 总结 (Summary) Chapter 5 练习 (Exercises) 5.1 区块 (Blocks) Common Lisp 有三个构造区块 (block )的基本操作符: progn 、 block 以 及 tagbody 。我们已经看过 progn 了。在 progn 主体中的表达式会依序求值,并 返回最后⼀个表达式的值: (progn (format t a) (format t b) (+ 11 12)) ab 23 由于只返回最后⼀个表达式的值,代表著使⽤ progn (或任何区块)涵盖了副作 ⽤。 ⼀个 block 像是带有名字及紧急出⼜的 progn 。第⼀个实参应为符号。这成为了区 块的名字。在主体中的任何地⽅,可以停⽌求值,并通过使⽤ return-from 指定区 块的名字,来⽴即返回数值: (block head (format t Here we go.) (return-from head idea) (format t We ll never see this.)) Here we go. IDEA 调⽤ return-from 允许你的程序,从代码的任何地⽅,突然但优雅地退出。第⼆个 传给 return-from 的实参,⽤来作为以第⼀个实参为名的区块的返回值。 在 return-from 之后的表达式不会被求值。 也有⼀个 return 宏,它把传⼊的参数当做封闭区块 nil 的返回值: (block nil (return 27)) 27 许多接受⼀个表达式主体的 Common Lisp 操作符,皆隐含在⼀个叫做 nil 的区块 ⾥。⽐如,所有由 do 构造的迭代函数: (dolist (x (a b c d e)) (format t ~A x) (if (eql x c) (return done))) A B C DONE 使⽤ defun 定义的函数主体,都隐含在⼀个与函数同名的区块,所以你可以: (defun foo () (return-from foo 27)) 在⼀个显式或隐式的 block 外,不论是 return-from 或 return 都不会⼯作。 使⽤ return-from ,我们可以写出⼀个更好的 read-integer 版本: (defun read-integer (str) (let ((accum 0)) (dotimes (pos (length str)) (let ((i (digit-char-p (char str pos)))) (if i (setf accum (+ (* accum 10) i)) (return-from read-integer nil)))) accum)) 8 页的版本在构造整数之前,需检查所有的字符。现在两个步骤可以结合,因为如果 遇到⾮数字的字符时,我们可以舍弃计算结果。出现在主体的原⼦ (atom )被解读为 标签 (labels) ;把这样的标签传给 go ,会把控制权交给标签后的表达式。以下是⼀ 个⾮常丑的程序⽚段,⽤来印出⼀⾄⼗的数字: (tagbody (setf x 0) top (setf x (+ x 1)) (format t ~A x)

文档评论(0)

aqlsxc66163 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档