Scheme语言--简单介绍
一年前事实上有时间看完SICP这本书,后来由于种种原因,一直没有继续再学。由于SICP中使用Scheme确实应用不多。在Java,C++的语言眼里,Scheme确实非常另类。现在MIT已经放弃了使用Scheme作为SICP的教学语言而转向python之际,我在此開始学习这本书与这门语言的学习。SICP主要使用Scheme语言来解决计算机科学中的一些问题。为了督促自己,每天都能学习。积小流而成江海,把自己的学习过程放在这里,以供自己复习。
本系列主要包含两部分Scheme语言层面的问题及SICP中的课程方面,两个部分相辅相成。今天開始Scheme语言的第一节。
Scheme简单介绍
Scheme语言是Lisp语言的一种变种,是一种表处理语言。其语法简单,easy学习,能够使使用者专著于解决这个问题而非语言本身。
1.1 基本类型
scheme支持的基本数据类型有整数,实数,分数,复数,对这些基本类型能够使用这些类型之上的各种操作如+-*/%等等。字符串””,记号quote。对于quote,(quote exp)表示exp为记号,不进行解析。常写作’exp。
List有两种类型,一种结尾元素为空表(),(list ‘a ‘b ‘c),等价与(cons ‘a (cons ‘b (cons ‘c ‘() ))),还有一种表为不正常表,表尾为结尾元素,(cons ‘a (cons ‘b ‘c)) 这样的表的值是(a b.c),.表示其后元素为表的结尾元素。
表的操作
car:取表的第一个元素
cdr:表在取car后的其余部分,对于正常表,其结果是一个表,对非正常表,结果可能是一个元素。
cons:构造表,假设第二个參数是表,则将第一个參数作为总体放在第二个參数的表中。
List:构造表,将各个參数做为总体放在一个表中。
构造正常表的还有一种方法:使用quote即’ 如’(a b c)。
1.2 变量绑定
( let ((arg1 val1) (argv2 val2) …) exp1 exp2 … )
变量绑定仅仅在当前的let表达式中有效,比如(let ((+ *)) (+ 2 3) =6)
Let操作能够嵌套运行,但绑定仅仅对let内部可见,对外层let不可见。
1.3 lambda表达式
(Lambda (arg1 …) exp1 exp2)
从演算来看,(let ((var value) …) exp1 exp2…) == ((lambda (var …) exp1 exp2 …) value … )
对于Lambda函数的參数
假设形參仅仅有一个,则能够有随意数量的实參,全部实參被格式化为一个list传给函数。
假设形參list是不正常的list的形式,则形參相应的实參被一一映射,而后的实參被格式化成一个list传给.后的形參,这也意味着,实參个数必须保证形參个数。假设形參是一个正常的list,则实參必须被一一映射。
因此((lambda (x) x) ‘a) = a 而((lambda x x) ‘a) = (a)
1.4 define定义
Define定义的是全局可见的,在scheme中,能够定义一个过程,当中使用一个没有定义的过程,这不会引起错误,但假设你使用它,就会出现错误,除非你补充定义了所引用的过程。
(define mylist (lambda x x))
1.5 条件表达式
If表达式:(if cond1 result1 result_other)
Cond表达式:( cond (test1 exp1) (test2 exp2) … (else expn ))也能够罗列全部,而不用else
Or表达式:(or exp1 exp2 …)
Not表达式:(not exp)使得#f #t之间转换。
关于类型推断:
(type? Var)能够得出var是否是type类型的,典型的类型有null,number,string,list,pair…
Eqv?能够推断两个值是否相等
1.6 递归过程
一个过程定义中调用了自己,递归过程一般分两部分,终止部分与递归部分。
1.7 map操作
( map fun argv …)
映射操作将fun应用到agv..的各个元素上,并返回一个list。以下是两个演示样例:
(map abs '(1 -2 3 -4 5 -6)) => (1 2 3 4 5 6)
(define trans
(lambda (lst)
(cons (map car lst) (map cdr lst))))
(trans '((a.1) (b.2) (c.3))) => ((a b c) 1 2 3)
1.8 赋值操作
Set!用来设置变量的值。变量能够是全局的,也能够是局部的。Set!使用的变量必须是事先定义过的。能够是let也能够是define。
Scheme语言--简单介绍的更多相关文章
- 这是啥-Cython语言简单介绍
Cython是一种既可以编写c又可以编写python的编程语言,他的目标是成为一个python语言的超集,为python提供高层次的.面向对象的.函数化.动态编程功能.不同于纯粹的python,它提供 ...
- R语言简单介绍
R语言 概述 R语言是用于统计分析,图形表示和报告的编程语言和软件环境. R语言由Ross Ihaka和Robert Gentleman在新西兰奥克兰大学创建,目前由R语言开发核心团队开发. R语言的 ...
- go语言简单介绍,增强了解
1. Go语言没有类和继承的概念,所以它和 Java 或 C++ 看起来并不相同.但是它通过接口(interface)的概念来实现多态性.Go语言有一个清晰易懂的轻量级类型系统,在类型之间也没有层级之 ...
- Tiny语言编译器简单介绍
1.简单介绍:编译器是将一种语言翻译成还有一种语言的程序.编译器将源程序的代码作为输出,从而产生用目标语言编写的等价程序.比如源码为C/C++等高级语言,那么目标语言就是目标机器的机器代码.也就是能够 ...
- 《R语言入门》语言及环境简单介绍
简单介绍 watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQv/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/diss ...
- R语言的帮助使用和图形功能简单介绍
R语言的帮助使用和图形功能简单介绍 R语言帮助,在Windows桌面下,有很多种.最长使用的是在命令行下help() > help.start() 会在浏览器中,打开帮助的主页 watermar ...
- HDFS简单介绍及用C语言訪问HDFS接口操作实践
一.概述 近年来,大数据技术如火如荼,怎样存储海量数据也成了当今的热点和难点问题,而HDFS分布式文件系统作为Hadoop项目的分布式存储基础,也为HBASE提供数据持久化功能,它在大数据项目中有很广 ...
- Phoenix(sql on hbase)简单介绍
Phoenix(sql on hbase)简单介绍 介绍: Phoenix is a SQL skin over HBase delivered as a client-embedded JDBC d ...
- OWIN产生的背景以及简单介绍
OWIN产生的背景以及简单介绍 随着VS2013的发布,微软在Asp.Net中引入了很多新的特性,比如使用新的权限验证模块Identity, 使用Async来提高Web服务器的吞吐量和效率等.其中一个 ...
随机推荐
- 关于在IISserver上执行asp.net Web程序出现以下 “Could not load file or assembly。。。”问题的
Could not load file or assembly 'System.EnterpriseServices, Version=4.0.0.0, Culture=neutral, Public ...
- Android底层开发之Linux输入子系统要不要推断系统休眠状态上报键值
Android底层开发之Linux输入子系统要不要推断系统休眠状态上报键值 题外话:一个问题研究到最后,那边记录文档的前半部分基本上都是没用的,甚至是错误的. 重点在最后,前边不过一些假想猜測. ht ...
- docker安装及问题处理
1.在Ubuntu的命令行中输入 sudo apt-get install docker.io 2.如果切换到了root用户下 apt-get install docker.io 3.对于新安装的Ub ...
- 硬件——STM32 , SN74HC573锁存器
74HC573是一款高速CMOS器件: 上图中:输出使能为:OE 锁存使能为:LE 典型电路: 上图中:PWR-AL-0,PWR-AL-1,PWR-AL-2:是单片机输出的高低电平给573 对应的 ...
- 【习题 5-2 UVA-1594】Ducci Sequence
[链接] 我是链接,点我呀:) [题意] 在这里输入题意 [题解] map加vector轻松搞定. [代码] #include <bits/stdc++.h> using namespac ...
- SQL Server 用链接server 同步MySQL
--測试环境SQL 2014 在MySql环境: use test ; Create Table Demo(ID int,Name varchar(50)) 在控制面板-管理工具-数据源(ODBC)- ...
- ASP.NET配置文件里经常使用到的节点信息
web.config文件是一个XML文件,是以<confirguration>为根结点展开的. 上一面从宏观上解说了一下有关配置的文件的内容,以下是一些有关于配置文件经常使用的操作. ...
- 使用vue-cil搭建项目
原文: 简书原文:https://www.jianshu.com/p/1af9b72cf86e 大纲 1.安装NodeJs 2.安装vue-cli 3.创建项目 4.启动项目 5.打包项目 6.项目实 ...
- HTML/CSS 选择符优先级
CSS的选择符优先级 1.同级样式默认后者覆盖前者 2.样式优先级 类型(1) < class[type](10)=伪类(10) < id(100) < style行间样式(1000 ...
- Java 网络I/O模型
网络I/O模型 人多了,就会有问题.web刚出现的时候,光顾的人很少.近年来网络应用规模逐渐扩大,应用的架构也需要随之改变.C10k的问题,让工程师们需要思考服务的性能与应用的并发能力. 网络应用需要 ...