Python报错:RecursionError: maximum recursion depth exceeded

  File "C:\User\AppData\Local\Programs\Python\Python312\Lib\difflib.py", line 182, in __init__
    self.set_seqs(a, b)
  File "C:\Users\AppData\Local\Programs\Python\Python312\Lib\difflib.py", line 193, in set_seqs
    self.set_seq1(a)
RecursionError: maximum recursion depth exceeded

📚情况说明:

之前程序运行一直很正常,突然出现这个问题,报错是在python源库里,也就是difflib。

对difflib进行了更新,也不行,找了下网上的解决办法,比如在spec文件中加入:

参考自这里:如何解决 RecursionError: maximum recursion depth exceeded-CSDN博客

import sys
sys.setrecursionlimit(100000) #设置递归深度

但还是没法解决我这边的问题,因为我这个不是exe执行文件的问题,是源代码问题。

📚原因分析:

Python默认递归调用深度为1000(即最多递归调用1000次),而程序在运行过程中超过最大的递归深度。

🛡️为什么最大递归深度要有限制呢?

本质上讲,在计算机中,函数调用是通过栈(stack)这种数据结构实现的,每当进入一个函数调用,栈就会加一层栈帧,每当函数返回,栈就会减一层栈帧。由于栈的大小不是无限的,所以,递归调用的次数过多,会导致栈溢出。
在递归调用中,每个函数在调用自己的时候 还没有退出,调用多了肯定会导致内存崩溃,因此需要对递归深度进行限制。

🌰举个形象的例子:

大家想象一下,你手里有10个盘子👇,你需要把它们一个个垒起来。很容易吧?你拿起第一个盘子垒好,再拿起第二个往上垒,就这样一直垒到最后一个盘子。

可是如果Python没有这个recursion depth的限制,你就可以无限制地垒盘子了。你一个劲地往上垒,盘子数量根本就装不下!到最后,盘子就会垒到房顶、垒到天上去,就会出现"盘子溢出"的狂野场景了!🤯我们程序如果遇到无限递归就会发生同样的"栈溢出"情况,内存像那些盘子一样被全部占满,就会导致程序崩溃。😱所以限制递归调用的深度是很重要的。

🤓聪明的Python为我们考虑到了这一点,在1000次递归调用之后就直接报错,不让程序陷入"盘子溢出"的窘境,省去了很多麻烦!

解决方法(一):

检查递归代码中是否有结束条件,避免死循环,以及递归结束条件是否合理。

解决方法(二):

在源代码修改默认的递归深度:

import sys  # 导入sys模块
sys.setrecursionlimit(100000)  # 将默认的递归深度修改为100000


 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值