clojure的binding和引用类型

binding
包括:全局binding,线程本地(thread local) binding ,函数内的本地binding,表达式内部的binding

1.全局binding:
def定义一个全局的binding,并且可以给它一个root value,这个root value在所有的线程里面是可见的,除非给它赋了一个线程本地的值。
2.函数内的本地binding
函数的参数是只在函数内可见的本地的binding
????属于哪种binding
let创建局限于一个当前form的bindings.它的第一个参数是一个vector,里面包含名字-表达式的对子。表达式的值会被解析然后赋给左边的名字。这些binding可以在这个vector后面的表达式里面使用。这些binding还可以被多次赋值改变它们的值,let命令剩下的参数是一些利用这个binding来进行计算的一些表达式。
注意:如果这些表达式有调用别的函数,那么这个函数是无法利用let创建的这个binding的。

宏binding与let类似,但是它创建的本地binding会暂时的覆盖已经存在的全局binding.
引用类型
Refs通过使用SoftwareTransactional Memory(STM)来提供对于多块共享数据的同步访问。
Atoms提供对于单个共享数据的同步访问。
Agents提供对于单个共享数据的异步访问。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Clojure 和 Python 是两种不同的编程语言,它们具有不同的设计哲学和特点。以下是对 Clojure 和 Python 进行比较的一些方面: 1. 语法和风格: - Clojure 是一种 Lisp 方言,其语法简洁、统一且拥有强大的宏系统。它使用括号表示表达式,具有强调函数式编程和不可变性的风格。 - Python 的语法更接近自然语言,使用缩进来表示代码块,具有直观和易读的风格。它既支持面向对象编程,也支持函数式编程。 2. 类型系统: - Clojure 是一种动态类型语言,变量的类型可以在运行时改变。它采用了基于值的不可变数据结构,并通过特定的函数操作来实现数据转换和处理。 - Python 也是一种动态类型语言,但它还支持静态类型检查(通过类型注解)。它使用了更传统的可变数据结构,并提供了丰富的内置数据类型和操作。 3. 并发和并行处理: - Clojure 在语言层面上支持并发和并行处理。它提供了一些内置的机制(如原子操作、锁和通道)来处理共享状态和并发访问。 - Python 的并发和并行处理需要借助于第三方库(如 threading、multiprocessing 和 asyncio)来实现。它提供了多线程和多进程编程的支持,以及异步编程模型。 4. 生态系统和库支持: - Python 拥有非常庞大和活跃的生态系统,有丰富的第三方库和工具可供选择,用于各种领域的开发,如科学计算、Web 开发、数据分析等。 - Clojure 的生态系统相对较小,但也有一些优秀的库和工具可供使用。它可以与 Java 生态系统进行互操作,可以利用 Java 的库和工具来扩展功能。 总体来说,Clojure 和 Python 在语法、类型系统和并发处理方面存在差异。Python 是一种通用的、易于学习和使用的语言,适合于快速开发和脚本编写。Clojure 则更适合于函数式编程和并发处理,对于处理大规模数据和构建高性能应用程序具有优势。选择哪种语言取决于具体的需求和个人偏好。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值