当同样的操作连续操作n次时,在命令式语言里是通过循环来控制连续操作的次数的,
譬如
List data = new ArrayList();
for(String s : {"aa", "b", ...} ){
data.add(s)
}
同类型的操作共享一个模型,都是重复墨重操作,在clojure里能把这些共同的模型抽象为macro,
在编译期进行宏扩展,从来形成一种公共模式,减少代码量。
其实现都是:
一个基本情况,通常是一次调用, 进行简单处理
多次调用, 对自己进行递归调用。
在core中这种宏有4个,
1: .. 连续调用方法,像jQuery里面的那种延续风格代码
(.. System getProperties (get "Path"))
2:-> 把第一个参数作为表达式的第一个参数,前一个表达式的结果作为下一个表达式的结果
(-> [1 2 3] pop pop)
3: ->> 把第一个参数插入到表达式的最后一个参数
(->> [] (cons 1) (cons 2))
4: doto 和->差不多,不过并不使用表达式的放回值作为下个表达式的参数,适用于具有操作有负效应的操作
(doto (java.util.HashMap.) (.put "1" "dd") (.put "2" "ff"))
使用返回值的延续操作和不使用返回值的延续操作实现上是不同,使用放回结果的要用返回值的替换先前的,
而不使用的可以直接通过map操作把多个操作映射到相同的对象上的。
譬如
List data = new ArrayList();
for(String s : {"aa", "b", ...} ){
data.add(s)
}
同类型的操作共享一个模型,都是重复墨重操作,在clojure里能把这些共同的模型抽象为macro,
在编译期进行宏扩展,从来形成一种公共模式,减少代码量。
其实现都是:
一个基本情况,通常是一次调用, 进行简单处理
多次调用, 对自己进行递归调用。
在core中这种宏有4个,
1: .. 连续调用方法,像jQuery里面的那种延续风格代码
(.. System getProperties (get "Path"))
2:-> 把第一个参数作为表达式的第一个参数,前一个表达式的结果作为下一个表达式的结果
(-> [1 2 3] pop pop)
3: ->> 把第一个参数插入到表达式的最后一个参数
(->> [] (cons 1) (cons 2))
4: doto 和->差不多,不过并不使用表达式的放回值作为下个表达式的参数,适用于具有操作有负效应的操作
(doto (java.util.HashMap.) (.put "1" "dd") (.put "2" "ff"))
使用返回值的延续操作和不使用返回值的延续操作实现上是不同,使用放回结果的要用返回值的替换先前的,
而不使用的可以直接通过map操作把多个操作映射到相同的对象上的。