LISP—向量

向量是一维数组,数组因此子类型。向量和列表统称序列。因此,我们迄今为止所讨论的所有序列的通用函数和数组函数,工作在向量上。

创建向量

向量函数使可以使用特定的值固定大小的向量。这需要任意数量的参数,并返回包含这些参数的向量。

示例1

创建一个名为main.lisp一个新的源代码文件,并在其中输入如下代码:

(setf v1 (vector 1 2 3 4 5))
(setf v2 #(a b c d e))
(setf v3 (vector 'p 'q 'r 's 't))
(write v1)
(terpri)
(write v2)
(terpri)
(write v3)

当执行代码,它返回以下结果:

#(1 2 3 4 5)
#(A B C D E)
#(P Q R S T)

请注意,LISP使用#(…)语法为向量的文字符号。可以使用此#(…)语法来创建并包含在代码中的文字向量。

然而,这些是文字向量,所以修改它们没有在LISP语言中定义。因此,对于编程,应始终使用向量函数,或者make-array函数来创建打算修改的向量。

make-array函数是比较通用的方式来创建一个矢量。可以访问使用aref函数的矢量元素。

示例 2

创建一个名为main.lisp一个新的源代码文件,并在其中输入如下代码:

(setq a (make-array 5 :initial-element 0))
(setq b (make-array 5 :initial-element 2))
(dotimes (i 5)
  (setf (aref a i) i))
(write a)
(terpri)
(write b)
(terpri)

当执行代码,它返回以下结果:

#(0 1 2 3 4)
#(2 2 2 2 2)

Fill 指针

make-array函数允许创建一个可调整大小的矢量。

函数fill-yiibaier参数跟踪实际存储在向量中的元素的数量。它的下一个位置,当添加元素的向量来填充的索引。

vector-push函数允许将元素添加到一个可调整大小的矢量的结束。它增加了填充指针加1。

vector-pop函数返回最近推条目,由1递减填充指针。

示例

创建一个名为main.lisp一个新的源代码文件,并在其中输入如下代码:

 
 
(setq a (make-array 5 :fill-yiibaier 0))
(write a)
(vector-push 'a a)
(vector-push 'b a)
(vector-push 'c a)
(terpri)
(write a)
(terpri)
(vector-push 'd a)
(vector-push 'e a)
;this will not be entered as the vector limit is 5
(vector-push 'f a)
(write a)
(terpri)
(vector-pop a)
(vector-pop a)
(vector-pop a)
(write a)

当执行代码,它返回以下结果:

#()
#(A B C)
#(A B C D E)
#(A B)

向量是序列,所有序列函数是适用于向量。请参考序列章节,对向量函数。

如果引用本站的原创文章,请注明原文链接:,本站保留追究责任的权利!

发表评论