今天写了一个Python脚本,运行过后发现提示RecursionError: maximum recursion depth exceeded 查询过相关文档和资料后才发现了问题原因,python的递归深度是有限制的...当递归深度超过1000时,就会报错。...解决方法直接修改Python的默认递归深度 import sys sys.setrecursionlimit(10**5) # 设置递归最大深度 10的5次方 递归是指函数/过程/子程序在运行过程序中直接或间接调用自身而产生的重入现象...在计算机编程里,递归指的是一个过程:函数不断引用自身,直到引用的对象已知。使用递归解决问题,思路清晰,代码少。 ? 扩展资料: 递归,就是在运行的过程中调用自己。...在数学和计算机科学中,递归指由一种(或多种)简单的基本情况定义的一类对象或方法,并规定其他所有情况都能被还原为其基本情况。
as e: # 在Python 3.5及更高版本中,更具体的RecursionError可能会被抛出 # 但由于RuntimeError是RecursionError的基类,这个...RecursionError, # 它是RuntimeError的一个特定子类,用于指示递归深度过大。...# 递归错误通常包含一个关于“超过最大递归深度”的消息。 # 由于递归深度限制是解释器的一个配置参数,因此具体的递归次数可能因Python版本和配置而异。...# 预期的运行结果(取决于Python解释器的递归深度限制): # 递归深度的打印输出,直到达到限制。...从 Python 3.5 开始,当递归深度超过解释器的限制时,通常会抛出 RecursionError 而不是 RuntimeError。
对象类型 分类 是否可变 数字 数值 否 字符串 序列 否 元组 序列 否 列表 序列 是 集合 集合 是 字典 映射 是 在使用的时候,需要我们注意的是python中的一切变量都是引用赋值的,除非你显示进行复制操作...集合只能包含不可变类型的对象 因为Python中的复合对象类型可以嵌套任意的对象类型,因此它们几乎可以表示任意的复杂数据。 嵌套对象在内部实际上被表示为指向不同内存区域的指针。...引用和复制 通常情况下,变量的引用赋值是符合我们预期的。如果你确实需要复制对象,那么可以使用下面的方法来实现。 浅拷贝 浅拷贝是指只对顶层进行复制操作,嵌套在内部的数据结构不会被复制。...使用构造函数进行复制 内置类型实际上也都是类,可以使用它们构造函数完成复制操作。例如:list(l),dict(d),set(s) 深拷贝 不仅仅复制顶层,也会复制嵌套的数据结构。...== 操作时,因为a中存储了自身的引用,会无限的递归与b比较,从而造成RecursionError异常,因为最大递归深度有一定的限制。
如果一个函数在内部调用自身,这个函数就叫做递归函数 递归函数的简单定义如下: def recursion(): return recursion() 这只是一个简单的定义,什么也做不了。...RecursionError: maximum recursion depth exceeded #超过最大递归深度 这类递归被称为无穷递归(infinite recursion),理论上永远都不会结束...其实函数每次被调用时都会创建一个新的命名空间,也就是当函数调用‘自己’时,实际上运行的是两个不同的函数(也可以说一个函数具有两个函数的命名空间)。 我们来看一个递归示例,计算阶乘n!...异常提示超过最大递归深度。...首先我们可以通过修改最大递归深度来增加递归深度。通过sys模块的setrecursionlimit()方法来修改。
在函数内部,可以调用其他函数。如果一个函数在内部调用自身本身,这个函数就是递归函数。...一个简单的递归函数(不正式) def calc(n): print(n) return calc(n) calc(10) 执行输出一堆10之后,报错 RecursionError:...maximum recursion depth exceeded while calling a Python object 提示调用该对象超过最大递归深度 查看python默认的最大递归深度,需要用...递归效率不高,递归层次过多会导致栈溢出(在计算机中,函数调用是通过栈(stack)这种数据结构实现的,每当进入一个函数调用,栈就会加一层栈帧,每当函数返回,栈就会减一层栈帧。...,它会返回一个 非负数 在执行add方法的时候,将abs赋值给f 那么return的时候,实际是 abs(3)+abs(-6) 最终结果为9
这是因为 Python 在内部建立了一个数组缓存,当创建小整数对象时,会直接引用缓存中已有的对象,而不是每次都创建新的对象。...在 Python 中,我们可以利用 copy 模块的 copy() 函数来创建一个对象的浅拷贝。...但如果原始对象包含其他可变对象(有嵌套的复杂对象,例如:列表中的列表和字典中的字典),则复制的对象将与原始对象共享内部子对象。这意味着对复制对象的内部子对象的修改也会反映在原始对象上。...如果对象之间存在循环引用,deepcopy() 会跟踪这些引用,并确保在复制过程中不会创建无限递归的复制。...此外,在某些情况下,如包含互相引用的对象,深拷贝可能会引起无限递归地尝试复制,直到达到 Python 的最大递归深度限制,从而引发 RecursionError。
代码第2行的if条件叫做递归的收敛条件,简单的说就是什么时候要结束函数的递归调用,在计算阶乘时,如果计算到0或1的阶乘,就停止递归调用,直接返回1;代码第4行的num * fac(num - 1)是递归公式...我们可以尝试执行fac(5000),看看是不是会提示RecursionError错误,错误消息为:maximum recursion depth exceeded in comparison(超出最大递归深度...我们使用的Python官方解释器,默认将函数调用的栈结构最大深度设置为1000层。如果超出这个深度,就会发生上面说的RecursionError。...当然,我们可以使用sys模块的setrecursionlimit函数来改变递归调用的最大深度,例如:sys.setrecursionlimit(10000),这样就可以让上面的fac(5000)顺利执行出结果...map函数的作用是以参数序列中的每个元素分别调用function函数,把每次调用后返回的结果保存为对象。
Python的浅拷贝和深拷贝的区别,相信你已经非常熟悉了,浅拷贝就是对原对象重新申请一个内存空间,但原对象的子对象如果是可变对象,仍然是存在引用关系的;深拷贝也是重新申请内存空间,以递归的方式,通过创建新的子对象拷贝到新对象中...不过,深度拷贝也不是完美的,先看段代码,你可以先预测下程序的输出,然后在执行下,看看预期是否一致。...x == y 程序执行到第 3 行时,x 已经是一个无限嵌套的列表,但是,执行到第 4 行时,程序进行了深度拷贝,就会递归的创建新的子对象,却并没有发生内存溢出的错误,这是为什么呢?...其实,这是因为深度拷贝函数 deepcopy 中会维护一个字典,记录已经拷贝的对象与其 ID。...: maximum recursion depth exceeded in comparison >>> 其原因也是 Python 的递归层数是有限定的,在 sys 模块中有个方法可以得到递归的层数:
没有退出条件的递归调用,就是无限调用 递归调用的深度不宜过深 Python对递归调用的深度做了限制,以保护解析器 超过递归深度限制,抛出RecursionError...:maxinum recursion depth exceeded超出最大深度、 sys.getrecursionlimit()查看最大深度 边界值:不是终止递归的返回值,而是作为递归运算最后一次运算的时调用的值...1.循环稍微复杂一些,但是只要不是死循环,可以多次迭代直至算出结果 2.fib函数代码极简易懂,但是只能获取到最外层的函数调用,内部递归结果都是中间结果.而且给定一个n都要进行近2n次递归,深度越深,效率越低...为了获取斐波那契数列需要外面在套一个n次的循环,效率就更低了 3.递归还有深度限制,如果递归复杂,函数反复压栈,栈内存很快就溢出了 1.间接递归,是通过别的函数调用了函数自身 2.但是,如果构成了循环递归调用时非常危险的...,但是往往这种情况在代码的情况下,还是可能发生这种调用。
对于普通人来说,深度学习中像Torch7这一类机器学习框架已经随手可及,深度学习对一系列的运用层面也有相当大的影响。 另外一个因为深度学习受益的领域是在普适计算方面的人类活动识别(HAR)。...深度学习在普适计算方面的人类识别活动上有机会造成很大影响。它可以替代缺乏有利于其他领域如语音识别强大的鲁棒性,设计了手动特征提取程序。然而,对于从业者来说困难的是选择为他们的应用最合适的深度学习方法。...在4000多个实验中,我们探讨HAR中每个超参数对不同的影响,为以后想将深度学习应用到他们的研究中的学者提供了参考。在这些实验的过程中我们发现,递归性网络实现了目前最佳的表现。 ?...当这个方法保留对RNN提出的样品排序时,它不允许每一个批梯度下降层,都关于类-分布。 4.实验 实验中研究的不同种类的超参数在表1中列出。...这一非线性模式随即被分解成为超参数的相互作用函数。fANOVA曾在递归函数中进行超函数探索。 对于探索者来说,知道模式的哪一方面对表现的影响最大是至关重要的。
” 7.5 递归 在7.1.2节编写斐波那契数列函数的时候,使用了 Python 中的递归(recursion)。固然 Python 创始人对递归有个人的看法,此处还是要用单独一节专门给予介绍。...各类资料中对递归的定义虽有所不同,但综合来看,都有“在被定义的对象中使用定义本身”的含义,例如: >>> def func(): ... x = 7 ... func() ......在实践中,绝对不允许出现这样的递归。Python 解释器会自动限制递归的深度,当达到该极限值时,会引发 RecursionError 异常,如上所示。...在真正的递归算法中,如同7.1.2节的斐波那契数列函数那样,必须有一个终止条件,即不需要进一步递归,就可以直接得到结果。在不满足终止条件时,每次递归都是逐渐接近此终止条件。...其实,在大多数情况下,编程中可以不用递归,即递归通常是不必须的——所以会有“递归已死”的观点。比如上面的“倒计时”,也可以用 while 循环实现。
# break # return # exit() # 控制变量 ... 8、函数递归 函数内部调用函数本身 函数有明确的递归跳出条件 不超出最大调用深度 # 函数递归的三个必备条件 ''' 1/函数体内部...,调用函数本身 2/递归够明确的跳出条件 3/不能超出最大调用深度 ''' # 需求: ''' func(1) = 1 func(2) = 1 + 2 = func(1) + 2 func(3) =...,是1000 也就是在Python中函数最多嵌套1000层 # 最大调用深度是为了保证系统性能的,否则无限递归下去,一会内存就满了 # 最大调用深度可以调整,可以调整到非常大的数字只要系统性能跟得上 #...RecursionError: maximum recursion depth exceeded in comparison # 注意事项: # 在编程初期,尽量少使用递归,但是要理解递归的特性,别人写的递归函数也要能看懂...= 1 else 1 # RecursionError: maximum recursion depth exceeded # 超出最大调用深度,没有明确的递归跳出条件 print(func1(100)
前言 前面讲到实例属性的时候,我们可以通过 来访问对应的实例属性 实例对象.实例属性 但这种做法是不建议的,因为它破坏了类的封装原则 正常情况下,实例属性应该是隐藏的,只允许通过类提供的方法来间接实现对实例属性的访问和操作...getter、setter 方法 不破坏类封装原则的基础上,操作实例属性 写过 java 的话应该知道,java 的类可以自动生成对属性的操作方法,一个是 get,另一个是 set(一般称为 getter...,但还是有点麻烦 property() 方法的诞生 可以实现在不破坏类封装原则的前提下,让开发者依旧使用 对例对象.属性 的方式操作类中的属性 基本使用格式 属性名 = property(fget=None...#name属性可读、可写、也可删除,就是没有说明文档 @property 是一个装饰器,相当于 getter 装饰器 可以使用 @property 来创建只读属性,将一个实例方法变成一个相同名称的只读实例属性...depth exceeded 报错翻译:递归错误 超过最大递归深度 其实就是因为命名冲突导致了死循环 改下命名就好了 class A: def __init__(self):
2020/5/27 13:35 */ public class HeapOOM { /** * 创建一个内部类用于创建对象使用 */ static class OOMObject...默认的栈容量在正常的方法调用时,栈深度可以达到1000-2000深度,所以,一般的递归可以承受的住,如果代码中出现了StackOverflowError,首先需要检查代码,看看是不是递归写的不对。...线程数*(最大栈容量)+最大堆值+其他内存(忽略不计或者一般不改动)=机器最大内存 当线程数比较多时,且无法通过业务上减少线程数,再不换机器的情况下,我们只能把最大栈容量设置小一点,或者把最大堆值设置小一点...这是因为在调用CGLib创建代理时会生成动态代理类,即Class对象到Metaspace,所以while一下就出异常了。...然后,介绍了栈内存异常(StackOverflowError)的发生场景以及处理方式,StackOverflowError发生的场景主要是线程调用栈深度超过了虚拟机运行的栈深度。
(在之前的调用返回后),空间就不够了,程序会以一个“超过最大递归深度”的错误信息结束。...当一个对象所属的类是另外一个对象所属类的子集时,前者就被称为后者的 子类(subclass),所以“百灵鸟类”是“鸟类”的子类。相反,“鸟类”是“百灵鸟类”的“超类”(superclass)。...尽管双下划线有些奇怪,但是看起来像是其他鱼鱼中的标准的私有方法。而在类的内部定义中,所有以双下划线开始的名字都被“翻译”成前面加上单下划线类名的形式。 >>> Secretive....如果不需要使用这种方法但是又想让其他对象不要访问内部数据,那么可以使用单下划线,这不过是个习惯,但的确有实际效果。...但并不是所有Python程序员都知道类的定义其实就是执行代码块。 7.2.5 指定超类 子类可以拓展超类的定义。将其他类名写在class语句后的圆括号内可以指定超类。
异常处理在任何一门编程语言里都是值得关注的一个话题。就像写函数时肯定是判断异常处理,然后在写业务逻辑代码,这样代码才更健壮。 每当发生让Python不知所措的错误时,它都会创建一个异常对象。...)函数创建的弱引用试图访问已经垃圾回收了的对象 ±- RuntimeError # 在检测到不属于任何其他类别的错误时触发 | ±- NotImplementedError # 在用户定义的基类中,抽象方法要求派生类重写该方法或者正在开发的类指示仍然需要添加实际实现...| ±- RecursionError # 解释器检测到超出最大递归深度 ±- SyntaxError # Python 语法错误 | ±- IndentationError # 缩进错误 | ±-...编译时指出的错误ZeroDivisionError是一个异常对象。 Python无法按照你的要求去做,就会创建这种对象。...下面创建了一个MyError类,基类为Exception,用于在异常触发时输出更多的信息。
,所以说是二路递归,每次递归后,范围缩小一半,所以该递归的深度是1+logn 多重递归 如果一个递归调用可以开始三个或者更多其他递归调用,我们称之为多重递归 例如: import os def disk_usage...python的最大递归深度 每一次递归都会有资源的消耗,每一次连续的调用都会需要额外的内存,当产生无限递归时,那就意味着资源的迅速耗尽,这明显是不合理的。...python为了避免这种现象,在设计时有意的限制了递归的深度,我们可以测试一下 def limitless(n): print('第' + str(n) + '次调用') n += 1...a Python object 最终递归到996次停止了递归,也就是python的递归深度限制在了1000附近。...因此在递归的调用中,这种未执行完的函数会一层一层的占用大量的栈帧。
我们平常所写的程序一般都是在编译环境下运行的,然而这对于那些没有开发环境或者对程序一无所知的小白就很不友好了, 所以在进行Python项目开发的后期,对于能够最大化的满足各类型用户的需求,十分有必要的一项工程就是软件打包成...Analysis类中的pathex定义了打包的主目录。 对于在此目录下的py文件可以只写文件名不写路径。...8)递归深度设置 将spec文件配置好以后在cmd中使用pyinstaller -XXX XXXX.spec (5)、在打包导入某些模块时,常会出现"RecursionError: maximum recursion...这可能是打包时出现了大量的递归超出了python预设的递归深度。...因此需要在spec文件上添加递归深度的设置,设置一个足够大的值来保证打包的进行, (6)pyinstaller库的参数 (7)Exe的图标文件格式为ico格式,可以直接在这个网站进行ico格式图标的转换
大家好,又见面了,我是你们的朋友全栈君。 递归函数 在函数内部,可以调用其他函数。如果一个函数在内部调用自身本身,这个函数就是递归函数。...RecursionError: maximum recursion depth exceeded in comparison **解决递归调用栈溢出的方法是通过尾递归优化,事实上尾递归和循环的效果是一样的..., 每一级递归都需要调用函数, 会创建新的栈,随着递归深度的增加, 创建的栈越来越多, 造成爆栈:boom: 尾递归(http://www.open-open.com/lib/view/open1480494663229...深入理解尾递归 呃, 所以呢? 是不是感觉还不够过瘾… 谁说尾递归调用就不用创建新的栈呢?...即返回depth深度调用的栈帧对象. import sys def get_cur_info(): print sys.
基类 以下异常通常用作其他异常的基类。 1、exception BaseException 这是所有内置异常的基类。它并不意味着被用户定义的类直接继承。对于用户定义的类,使用Exception。...此类负责使用传递的参数使用str()创建异常的字符串表示形式。如果没有参数,则返回一个空字符串。 args: args是提供给异常构造函数的参数的元组。...此方法将tb设置为该异常的新回溯并返回异常对象。...5、exception LookupError 这是在映射或序列上使用的键或索引无效或找不到时引发的那些异常的基类。...当解释器检测到超过最大递归深度时,将引发此异常。 异常ReferenceError 当在垃圾回收之后使用弱引用代理访问引用对象的属性时,引发ReferenceError。
领取专属 10元无门槛券
手把手带您无忧上云