python递归调用中会遇到什么问题-创新互联
这篇文章给大家分享的是有关python递归调用中会遇到什么问题的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。
在阳曲等地区,都构建了全面的区域性战略布局,加强发展的系统性、市场前瞻性、产品创新能力,以专注、极致的服务理念,为客户提供网站制作、做网站 网站设计制作定制设计,公司网站建设,企业网站建设,高端网站设计,网络营销推广,外贸网站建设,阳曲网站建设费用合理。问题:
前几天写一个小面试题, 忽然有个惊悚的发现, 如下:
s1 = 'abcdefg' def right_shift(s, n): """ 把传入的字符串,前n个字符移动到最后面 """ if n < 1: print(s) # 此步输出结果为 "efgabcd" return s s = s[1:] + s[0] n -= 1 right_shift(s, n) s = right_shift(s1, 4) print(s)# 此步输出结果为 None
输出结果让我百思不得其解, 为什么明明上一步输出有值, return出去后就变成了None??
解决方法: return function()
今日在写一个装饰器的时候偶然想起一个可能, 把函数内最下面一行right_shift(s, n) 改为return right_shift(s, n)即可! 修改后代码如下:
s1 = 'abcdefg' def right_shift(s, n): """ 把传入的字符串,前n个字符移动到最后面 """ if n < 1: # print(s) return s s = s[1:] + s[0] n -= 1 # 加入return, 其原理根装饰器的闭包接近! return right_shift(s, n) s = right_shift(s1, 4) print(s) # 成功输出 "efgabcd"
知识点补充:python 递归返回None 解决
今天写了一个递归 return 之前答应出来都是有值的, 调用时候返回值都是None ,很是纳闷 后来找到原因
现在来看下返回None 的代码
def get_end_parent_ele(self, obj): """获取这个id 所在的原始类""" parent_id = obj.parent_id if obj else 0 OHHOLog.print_log("获取这个id parent_id") OHHOLog.print_log(parent_id) parent_obj = self.obj_obj.get_by_id(parent_id) if parent_obj.key == "all": OHHOLog.print_log("all") return_key = obj.key OHHOLog.print_log(return_key) return return_key else: self.get_end_parent_ele(parent_obj)
修改将下面的也给返回
def get_end_parent_ele(self, obj): """获取这个id 所在的原始类""" parent_id = obj.parent_id if obj else 0 OHHOLog.print_log("获取这个id parent_id") OHHOLog.print_log(parent_id) parent_obj = self.interest.get_by_id(parent_id) if parent_obj.key == "all": OHHOLog.print_log("all") return_key = obj.key OHHOLog.print_log(return_key) return return_key else: return self.get_end_parent_ele(parent_obj)
没有return的时候数据只能进不能出所以就只能返回None
感谢各位的阅读!关于“python递归调用中会遇到什么问题”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,让大家可以学到更多知识,如果觉得文章不错,可以把它分享出去让更多的人看到吧!
分享名称:python递归调用中会遇到什么问题-创新互联
URL链接:http://scjbc.cn/article/dhccsc.html