python防止棧溢出的實(shí)例講解
使用遞歸函數(shù)的優(yōu)點(diǎn)是邏輯簡(jiǎn)單清晰,缺點(diǎn)是過深的調(diào)用會(huì)導(dǎo)致棧溢出。
解決遞歸調(diào)用棧溢出的方法是通過尾遞歸優(yōu)化,事實(shí)上尾遞歸和循環(huán)的效果是一樣的,所以,把循環(huán)看成是一種特殊的尾遞歸函數(shù)也是可以的。
2、實(shí)例def fact(n): return fact_iter(n, 1) def fact_iter(num, product): if num == 1:return product return fact_iter(num - 1, num * product) # fact(5)的調(diào)用過程===> fact_iter(5, 1)===> fact_iter(4, 5)===> fact_iter(3, 20)===> fact_iter(2, 60)===> fact_iter(1, 120)===> 120
知識(shí)點(diǎn)擴(kuò)展:
棧溢出
在計(jì)算機(jī)中,函數(shù)調(diào)用是通過棧(stack)這種數(shù)據(jù)結(jié)構(gòu)實(shí)現(xiàn)的,每當(dāng)進(jìn)入一個(gè)函數(shù)調(diào)用,棧就會(huì)加一層棧幀,每當(dāng)函數(shù)返回,棧就會(huì)減一層棧幀。由于棧的大小不是無限的,所以,遞歸調(diào)用的次數(shù)過多,會(huì)導(dǎo)致棧溢出。可以試試fact(1000):
>>> fact(1000)Traceback (most recent call last): File '<stdin>', line 1, in <module> File '<stdin>', line 4, in fact ... File '<stdin>', line 4, in factRuntimeError: maximum recursion depth exceeded
到此這篇關(guān)于python防止棧溢出的實(shí)例講解的文章就介紹到這了,更多相關(guān)python如何防止棧溢出內(nèi)容請(qǐng)搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!
相關(guān)文章:
1. PHP中為什么使用file_get_contents("php://input")接收微信通知2. ASP基礎(chǔ)入門第二篇(ASP基礎(chǔ)知識(shí))3. ASP.NET MVC實(shí)現(xiàn)登錄后跳轉(zhuǎn)到原界面4. 不使用XMLHttpRequest對(duì)象實(shí)現(xiàn)Ajax效果的方法小結(jié)5. ThinkPHP6使用JWT+中間件實(shí)現(xiàn)Token驗(yàn)證實(shí)例詳解6. 怎樣打開XML文件?xml文件如何打開?7. ASP.NET MVC限制同一個(gè)IP地址單位時(shí)間間隔內(nèi)的請(qǐng)求次數(shù)8. JSP出現(xiàn)中文亂碼問題解決方法詳解9. vue的路由動(dòng)畫切換頁面無法讀取meta值的bug記錄10. jsp實(shí)現(xiàn)簡(jiǎn)單用戶7天內(nèi)免登錄
