【转】Clojure FP之6大规则

《Clojure程序设计》函数式编程6大规则:

1.避免直接递归。Java虚拟机无法优化递归调用,Clojure的递归程序会撑爆它们的栈空间

2.当产生的是标量(scalar values),或者体积小还数量固定的序列时,你可以使用recur。Clojure会对现实的recur进行调用优化。

3.当产生个头大,或是大小可变的序列时,让它成为惰性的,而不要用递归。这样,你的调用者就只需要为他们实际需要的那一部分买单。

4.小心不要让一个惰性序列变现的太多,多的超出你的需要。

5.熟悉序列库。这样你就总能写出完全用不着recur或者惰性API的代码了。

6.细分。把看似简单的问题也尽可能划分为更小的块。这样你就能发现蕴藏于序列库中的解决方案。于是代码更通用,可重用性也会更好。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值