`
阿尔萨斯
  • 浏览: 4200910 次
社区版块
存档分类
最新评论

Lisp语言:数组

 
阅读更多
讨论了变量以后让我们来看看Lisp中的数组,对于非Lisp程序员来讲这是再自然不过的了,很多编程语言的教材上都是在讲述了一般性语法后讲解数组。不过,Lisp程序员可能会有点疑问,为什么不开始介绍列表呢?列表作为Lisp语言的关键在Lisp中起到了重要的作用,所以很多有关Lisp的材料都是以介绍列表开始,这对于一般程序员来讲有在思路转换上有点困难。所以在这里还是按一般程序员的习惯,先介绍数组等常见的数据结构。


首先是有关数组的定义,Lisp中数组的定义使用make-array函数,下面是数组定义的样例:

(setf test-array-1 (make-array 10 :initial-element 5))
以上代码定义了一个数组名为test-array-1,数组元素有10个,元素初值为5.

其中数组是通过(make-array 10 :initial-element 5)生成的,生成后通过setf赋予了变量test-array-1。


定义了数组后就需要开始使用它,使用过程需要知道一个数组的长度。数组的长度可以使用函数length获取,下面是样例:

(length test-array-1)

以上语句通过length获取test-array-1的长度,按以上的定义,这里会返回10,表示数组test-array-1中有10个元素。


对数组的进一步操作最常见的就是获取指定位置的元素,如获取一个数组第5个元素。

获取数组的某一个元素通过函数aref完成,下面是样例

(aref test-array-1 5)
以上代码获取了test-array-1中的第6个元素。这里注意代码中使用了数字5,取出来的元素是第6个,因为Lisp和其它一般语言一样将0作为数组的起始下标。


结合以上几个函数,遍历打印一个数组的代码如下:

    (setf end-index (- (length test-array-1 ) 1))
        (loop for i from 0 to end-index do
                (format *query-io* "element ~a is ~a ~%"
                        i
                        (aref test-array-1 i)))

这里没有使用Lisp中的迭代方法,而是简单使用了loop循环,从0开始直到9,通过aref函数逐个取出元素,然后打印出来。


以上方法是遍历一个数组是需要使用的,很多时候我们还需要对数组的特定元素进行赋值操作。

Lisp中对一个数组的元素进行赋值可以通过aref取的对应元素,然后直接通过setf对它进行赋值,下面是一个样例:

(setf (aref test-array-1 5) 50)
以上代码将test-array-1数组中的第6个元素(注意,不是第5个元素)的值设置成50.


结合以上所有样例,数组使用的完整样例如下:

(defun array-test ()
        ;定义数组
        (setf test-array-1 (make-array 10 :initial-element 5))

        ;输出数组长度

        (format *query-io* "test array has ~a elements~%" (length test-array-1))
        ;获取数组长度,保存到end-index
        (setf end-index (- (length test-array-1 ) 1))

        ;循环打印数组

        (loop for i from 0 to end-index do
                (format *query-io* "element ~a is ~a ~%"
                        i
                        (aref test-array-1 i)))

        ;将第6个元素设置为50
        (format *query-io* "setting element 5 to 50 ------~%")
        (setf (aref test-array-1 5) 50)

        ;再次循环输出数组
        (loop for i from 0 to end-index do
                (format *query-io* "element ~a is ~a ~%"
                        i 
                        (aref test-array-1 i)))
)

样例执行截图如下:


分享到:
评论

相关推荐

    拓广AUTOLISP语言集方法及数组运算解释函数设计 (1993年)

    利用AUTOLISP 的潜在功能可拓广其函数集,不必涉及其存贮分配,文中介绍AUTOLISP的潜在函数功能,讨论数组运算解释函数的设计方法.

    js-lisp:JavaScript中的类似于Toy Lisp的语言解释器

    javascript中的类似lisp的玩具语言。 互动模式: 入门 交互式运行: $ node js-lisp.js 运行测试: $ cd js-lisp $ npm install $ ./node_modules/.bin/nodeunit 去做 有关黑客的一些想法: 防御 引用/取消...

    json-lisp:https

    JSON Lisp是一种类似于Lisp的语言,它使用JSON数组来模拟Lisp S-Expression。 该存储库是参考资源,以支持我关于该主题的文章。 查阅,我们将在其中共同实现该语言。 例子 数学 [ "+" , 2 , 2 ] ; // 4 if [ "if...

    stutter:从头开始用 C 语言实现 Lisp,没有库

    换句话说, stutter是一系列广泛的 CS 主题的实践练习,包括形式语言(词法分析、语法分析、抽象语法树) 元语言评估(eval/apply,宏) 数据结构(列表、树、地图、数组) 自动内存管理(标记和清除垃圾收集) ...

    continuable-minimal-lisp:可持续的miniMAL Lisp是使用TypeScript编写的,具有suspendresume支持的miniMAL实现

    您可以找到语言规范它与Java脚本具有很好的互操作性。特征继承: 程序是用JSON或简单的Javascript数组树编写的。 巨集尾部呼叫优化(TCO) Javascript互操作性错误处理无依赖关系(用作库) 和更多... 暂停/恢复在...

    LST:具有简单类型系统的Lisp,用FORTH编写

    数组: [10] INT , [10][10] REAL 参考/指针: REF INT , REF [10] REAL , REF REF [10][10] ANY 功能/程序: FORMAL (INT, INT) VOID 结构/记录: CARTES (INT, INT) 结构/记录和选择器: CARTES ((length,...

    worldwindjava源码-glossary:Lisp俚语及其他术语词典

    中存储关联数组的常用方法。 alist 可以存储重复的键。 当键的顺序无关紧要并且不需要重复键时,哈希表(所有流行的 Lisp 实现提供的不透明数据类型)通常用于更快地查找。 照应宏 — 使用变量捕获来定义诸如it或...

    taylor:测量两次,切一次。 类似于Lisp的功能语言,用于可计算和不变的规范,由WebAssembly和以太坊虚拟机解释

    下一版本(0.0.4):有符号整数,矩阵构造,n维数组创建,切片和转换,矩阵乘法。 试试看: : 演示: : list 尝试的示例:(一次只能一行!) (add (add (sub 7 2 ) 1 ) 41 ) ( list 5 4 (add 6 2 ) 3 (sub 6...

    access:一个通用的Lisp库,用于统一对类似于字典的通用数据结构的访问

    使用权一个通用的Lisp库,用于统一对最常用数据结构的访问,并允许您按原样对其进行操作(即,作为一堆具有稍微不同的api的字典)访问,访问,(setf访问),(setf访问) 这些功能允许统一访问以下数据结构: 访问...

    telescope:玩具Lisp口译员

    望远镜 受“和启发, Telescope是Lisp族的一种语言,我构建该语言是为了更好地理解编程语言的世界(并学习Rust)。 因为世界需要更多文明的语言。 望远镜是根据Scheme的简单性建模的,具有Clojure的敏感性和语法。 ...

    多行:多行,从函数调用和定义到数组和映射文字的各种语言,包括多种语言

    多行:多行,从函数调用和定义到数组和映射文字的各种语言,包括多种语言

    kona:K编程语言的开源实现

    同样,与LISP一样,k语言也是基于ASCII的,因此您不需要特殊的键盘。 对于许多人来说,k是首选的APL方言。 当它可用时,它往往会受到投资银行家的青睐,其性能被困扰,而分析师则处理大量数据。 这是一门苛刻的...

    BQN:一种类似APL的编程语言。 自托管!

    ),使其成为学习数组编程和建立更强大的数组直觉的良好语言。 BQN保留了许多使1966年APL \ 360具有革命性意义的思想: 人性化的后缀表示法没有要记住的优先级规则。 轻松处理任意数量的尺寸。 高阶函数允许以更...

    language-matrix:代码段可为11种语言做有用的事情

    例如,如果您使用Java查找方法,则应该在Groovy,LISP,C,C ++等中找到相同的示例。对原始示例的任何派生将以更加清晰和解释的方式呈现。它不会做什么? 它不会涵盖多种不同语言的库。 这只是侧重于语言本身及其...

    QNial7:NIAL语言环境

    目标是将基于APL数组的编程的优势与从LISP借用的实现概念,从Algol来的结构化编程思想以及从FP来的功能编程概念相结合。 解释器最初是为Unix开发的,它足够小,可以在当时新发布的IBM PC上运行,并且足够轻便,可以...

    Ruby 小白入门指南理解 Ruby 及其特点.txt

    Ruby 的灵感来源于 Perl、Smalltalk、Eiffel、Ada 和 Lisp 等多种语言,它继承了这些语言的优点,同时增加了自己的特性。 二、安装 Ruby 环境 在开始编程之前,你需要在你的计算机上安装 Ruby 环境。你可以从 Ruby...

    Javascript函数式编程语言

    函数式编程语言 函数式编程语言是那些方便于使用函数式编程...同时,纯函数语言也无法使用面向对象编程,比如Scheme、Haskell以及Lisp。 然而有些语言两种模式都支持。Python是个著名的例子,不过还有别的:Ruby,Jul

    Petalisp:优雅的高性能计算

    它不是一种完善的编程语言,而是Common Lisp的精心设计的扩展,可以实现极端的优化和并行化。 入门 安装Lisp和合适的IDE。 如果不确定,请选择 。 通过下载Petalisp。 查看一些。 展示柜 Petalisp仍在开发中,...

    oyoy:牡蛎(一种口齿不清的东西)希望有一天能用 pypy 进行 JIT 编译

    Oyster 是一种编程语言。 它受 lisp 的影响很大(尽管每次迭代它变得不那么像 lisp)。牡蛎牡蛎是口齿不清的; 但不是围绕 cons 单元构建,而是围绕数组和哈希表构建。 Oyster 的语法基于@AdamHeck 设计的...

    java8集合源码-my-stars:我加星标的所有存储库

    的类型安全动态数组实现 - 用 C 编写的轻量级和低级创意编码工具包。 - qLibc 是一个简单而强大的 C 库 - 用 C 编写的常用数据结构和算法库。 - 一个简单的展示如何在没有任何 Objective-C 的情况下用纯 C 语言创建...

Global site tag (gtag.js) - Google Analytics