Lisp中的所有数据都是不可变的吗?
在中,作者称赞函数式编程有两个主要的好特性。 但他没有提到(普通的)口齿不清Lisp中的所有数据都是不可变的吗?,lisp,Lisp,在中,作者称赞函数式编程有两个主要的好特性。 但他没有提到(普通的)口齿不清 Lisp的数据是否满足“所有数据都是不可变的”?否。通用Lisp中的数据不是不可变的 如SBCL中所示,使用setf功能 * (setf x 0) 0 * x 0 * (setf x 1) 1 * x 1 在Common Lisp中,您可以选择使用函数式样式。避免使用setf、setq,这样就可以使用函数式编程语言。换句话说,不要更改任何变量值,不要在创建后更改复合数据结构(cons、vectors、structur
Lisp的数据是否满足“所有数据都是不可变的”?否。通用Lisp中的数据不是不可变的 如SBCL中所示,使用
setf
功能
* (setf x 0)
0
* x
0
* (setf x 1)
1
* x
1
在Common Lisp中,您可以选择使用函数式样式。避免使用
setf
、setq
,这样就可以使用函数式编程语言。换句话说,不要更改任何变量值,不要在创建后更改复合数据结构(cons、vectors、structures等)的内容。函数接受输入并生成输出,而不修改状态
因此,虽然Common Lisp提供了一些必要的操作,但如果您不想使用这些操作,则不必使用它们。在Common Lisp中,所有数据(如基本变量引用、列表、数组和哈希表)在默认情况下都是可变的,因此没有任何东西可以阻止用户更改变量的值,序列的元素或结构的字段 但是,如果我们谈论的不是原始数据类型,而是用户定义的数据,即CLOS结构和类,那么它们的插槽可以设置为只读。例如,对于结构:
(defstruct person
(name nil :type string :read-only t)
(age nil :type (integer 0 100)))
(let ((john (make-person :name "John" :age 30)))
(princ john)
;; * `age' is mutable:
(incf (person-age john))
(princ john)
;; * `name' is not:
;; (setf (person-name john) "garbage name")
;; ^ you can't do this because the `defstruct' macro just don't emit SETFer
;; for the `name' slot as you made it read-only.
)
类为插槽提供了更多的访问控制(这类似于C中的const
限定符的机制,不同之处在于在常见的Lisp中,它不是编译时保证,而是可以在重新启动时处理的异常),您可以为它们提供读写、只读、只读或无访问
有关详细信息,请参阅以下链接: