博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Python尾递归-创始人为何不愿TRE以及我们如何模拟TRE
阅读量:6284 次
发布时间:2019-06-22

本文共 1660 字,大约阅读时间需要 5 分钟。

TRE=Tail Recursion Elimination

创始人是不愿意实现TRE的.他专门用了一篇文章来阐述原因.

1.不利于查BUG.

2.现有的1000递归深度够用.

3.递归不是所有编程的基础,也不是一个日常工具.

4.他举了个例子说明第四点,大概是指Python动态的特性不适合递归:

def f(x):    print 'original'    if x > 0:        return f(x-1)    return 0g = fdef f(x):    print 'new'    return xprint g(5)

最终结果是4:

originalnew4

最后总结:

After all TRE only addresses recursion that can easily be replaced by a loop.

意思应该是说所有真正需要TRE的地方都能轻松改写为循环.

看来我是不能指望Python语言支持TRE了.

 

但还是有很多顽强的程序员用各种方法变相支持TRE.比如下面这位还用装饰器的形式实现了.

class TailCaller(object) :    def __init__(self, f) :        self.f = f    def __call__(self, *args, **kwargs) :        ret = self.f(*args, **kwargs)        while type(ret) is TailCall :            ret = ret.handle()        return retclass TailCall(object) :    def __init__(self, call, *args, **kwargs) :        self.call = call        self.args = args        self.kwargs = kwargs    def handle(self) :        if type(self.call) is TailCaller :            return self.call.f(*self.args, **self.kwargs)        else :            return self.f(*self.args, **self.kwargs)@TailCallerdef fact(n, r=1) :    if n <= 1 :        return r    else :        return TailCall(fact, n-1, n*r) print fact(2500)

 

最朴素的形式是:

def TCO(f):        def inner(*nkw,**kw):        result=f(*nkw,**kw)        while callable(result):            result=result()        return result    return inner        def fab(n,s=1):    if n<2:        return s    else:        return lambda :fab(n-1,s*n)tcoFab=TCO(fab)print tcoFab(2500)

这个更容易理解,性能也应该会更好,只是行文略显复杂了一点点.主要是由于Python运行时的动态特性,你不能使用更酷的装饰器形式fab=TCO(fab).

我个人是比较支持这种朴素形式的.

 

网上还有其他一些什么抛出异常法之类的,用到了sys模块,太复杂了,看不懂,故不用.

转载于:https://www.cnblogs.com/xiangnan/p/3407780.html

你可能感兴趣的文章
LCD的接口类型详解
查看>>
Spring Boot Unregistering JMX-exposed beans on shutdown
查看>>
poi 导入导出的api说明(大全)
查看>>
Mono for Android 优势与劣势
查看>>
将图片转成base64字符串并在JSP页面显示的Java代码
查看>>
js 面试题
查看>>
sqoop数据迁移(基于Hadoop和关系数据库服务器之间传送数据)
查看>>
腾讯云下安装 nodejs + 实现 Nginx 反向代理
查看>>
Javascript 中的 Array 操作
查看>>
java中包容易出现的错误及权限问题
查看>>
AngularJS之初级Route【一】(六)
查看>>
服务器硬件问题整理的一点总结
查看>>
SAP S/4HANA Cloud: Revolutionizing the Next Generation of Cloud ERP
查看>>
Mellanox公司计划利用系统芯片提升存储产品速度
查看>>
白帽子守护网络安全,高薪酬成大学生就业首选!
查看>>
ARM想将芯片装进人类大脑 降低能耗是一大挑战
查看>>
Oracle数据库的备份方法
查看>>
Selenium 自动登录考勤系统
查看>>
关于如何以编程的方式执行TestNG
查看>>
智能照明造福千家万户 家居智能不再是梦
查看>>