js-读书笔记-函数式编程-生成器

import _ from 'underScore'
import Utils from '../lib/utils.js'
// 生成器
function generator(seed, current, step) {
  return {
    head: current(seed),
    tail: function() {
      // console.log('forced')
      return generator(step(seed), current, step)
    }
  }
}

const genHead = gen => gen.head
const genTail = gen => gen.tail()

const ints = generator(0, _.identity, n => n + 1)

console.log(genHead(ints))
console.log(genTail(ints))

const genTake = (n, gen) => {
  let doTake = function(x, g, ret) {
    if(x === 0 ) {
      return ret
    } else {
      return Utils.partial(doTake, x - 1, genTail(g), Utils.cat(ret, genHead(g)))
    }
  }
  return Utils.trampoline(doTake, n, gen, [])
}
console.log(genTake(10, ints))
console.log(genTake(100, ints))
console.log(genTake(1000, ints))

缺陷:每次访问都要再计算一次。
如果不直接使用蹦床,一般的蹦床化的思想在js中一文不值。
尽可能的使用堆,而不是栈,因为堆比调用栈大得多,所以使用蹦床时不太可能遇到内存耗尽的问题。
递归的一个底层的操作,应该尽量避免。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值