欢迎来到天天文库
浏览记录
ID:32519072
大小:134.80 KB
页数:14页
时间:2019-02-10
《scheme语言深入》由会员上传分享,免费在线阅读,更多相关内容在应用文档-天天文库。
1、Scheme语言深入在Scheme语言中,符号类型的用法、过程的多参数情况、Continuation、记录类型、宏定义与模块等等一些问题成为阻挡初学者的门槛,也是深入理解和使用Scheme语言编程的关键,下面分别论述,做为对《Scheme语言概要》一文的补充。现在就开始免费试用一、关于符号类型符号类型又称引用类型,在概要一文中本人介绍得非常的模糊,使很多初学者不理解。符号类型在Scheme语言中是最基础也是最重要的一种类型,这是因为Scheme语言的祖先Lisp语言的最初目的就是符号处理,在Sch
2、eme语言中几乎所有的东西都可以看做是符号或做为符号列表来处理,这也是我们把符号类型做为第一个问题研究的原因。与符号类型相关的关键字有四个,分别是:quote,quasiquote,unquote和unquote-splicing,如下所示:规范用法:(quoteobj) 简化用法:'obj(注意,'为右单引号,"双引号下面的那个符号。) 意义:符号类型的定义,(quoteobj)本身就是一个值,虽然它不如数字123这样直观。规范用法:(quasiquoteobj) 简化用法:`obj(注意,`为
3、左单引号,~波浪号下面的那个符号。) 意义:"类似符号"类型的定义,最好称之为逆符号类型,它可以将符号类型转换为具有实际意义的东西。规范用法:(unquoteobj) 简化用法:,obj(注意,,逗号,<小于号下面的那个符号。) 意义:"非符号"类型的定义,非符号类型出现在符号类型或逆符号类型定义中间,它不直接做为符号类型使用,而是将运算结果做为符号类型的一部分。规范用法:(unquote-splicingobj) 简化用法:,@obj 意义:非符号类型的拼接,注意:,@两个符号做为一个操作符来使
4、用)。当非符号类型是一些复杂算法时,需要用它来做一下拼接,以达到符号类型的目的。 上面所说的所有规范用法和简化用法的功能都是相同的。符号类型的意义在于,一个说明,英文单词zebra指的是活生生的斑马,而'zebra或(quotezebra)指的是由字母z、e、b、r、a构成的这串符号(不是字符串),就象我们定义变量(definex100),这时x指的就是100这个数值,而'x或(quotex)则代表字母x构成的这个符号。首先看一段代码:guile>(defines'(goodmorning))gu
5、ile>s(goodmorning)guile>(symbol?s)#fguile>(list?s)#tguile>(symbol?(list-refs1))#t从此示例中可以看出,用quote定义的列表的类型仍是列表,而列表中的某一值的类型则是符号类型。还可以看出有点类似于如下:(+1(+2(+3(+45))))==>(+12345)(list'a'b'c'd'e)==>'(abcde)两者有异曲同工之妙,减少了多余的操作符,使表达式更直观,更容易理解。从'(12345)==>(12345)可以
6、看出,由符号类型的定义来形成列表,这是Scheme语言继承自LISP语言的传统。下面是在guile中的用法示例:guile>`(1,(+11)3)(123)guile>(quasiquote(1(unquote(+11))3))(123);;;第一个是简化用法,第二个是标准用法。guile>`(1,@(map+'(13)'(24))9)(1379)guile>(quasiquote(1(unquote-splicing(map+(quote(13))(quote(24))))9))(1379);;
7、;第一个是简化用法,第二个是标准用法(注意:,@两个符号做为一个操作符来使用)。从示例中我们可以看出,这些应用多数与列表有关,而处理列表是Scheme语言的关键所在。符号类型的用法对深入理解Scheme语言也非常关键,因为Scheme语言本身就可以理解为是这种符号类型的列表,处理符号类型就是处理Scheme语言本身。回页首二、关于尾递归数列问题是研究递归的非常好的范例,在王垠的主页中有关于用菲波那契数列来说明非尾递归与尾递归之间区别和尾递归的好处的一个例子,见 http://learn.tsing
8、hua.edu.cn/homepage/2001315450/wiki/TailRecursion.html 。我们这里用更简单一点的问题,求累计的问题来说明,即求自然数1+2+3+4+...+n的和。事实上就是设计一个过程,给它一个参数n,求1+2+3+...+n的和,我们首设计一个suma过程,代码如下:#!/usr/local/bin/guile-s!#(definesuma(lambda(n)(if(=n1)1(+n(suma(-n1))))))(display"(suma
此文档下载收益归作者所有