python防止棧溢出的實(shí)例講解
使用遞歸函數(shù)的優(yōu)點(diǎn)是邏輯簡(jiǎn)單清晰,缺點(diǎn)是過(guò)深的調(diào)用會(huì)導(dǎo)致棧溢出。
解決遞歸調(diào)用棧溢出的方法是通過(guò)尾遞歸優(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)用過(guò)程===> 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)用是通過(guò)棧(stack)這種數(shù)據(jù)結(jié)構(gòu)實(shí)現(xiàn)的,每當(dāng)進(jìn)入一個(gè)函數(shù)調(diào)用,棧就會(huì)加一層棧幀,每當(dāng)函數(shù)返回,棧就會(huì)減一層棧幀。由于棧的大小不是無(wú)限的,所以,遞歸調(diào)用的次數(shù)過(guò)多,會(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. 刪除docker里建立容器的操作方法2. 使用 kind 和 Docker 啟動(dòng)本地的 Kubernetes環(huán)境3. IntelliJ IDEA導(dǎo)出項(xiàng)目的方法4. Docker容器如何更新打包并上傳到阿里云5. IntelliJ IDEA設(shè)置條件斷點(diǎn)的方法步驟6. Docker究竟是什么 為什么這么流行 它的優(yōu)點(diǎn)和缺陷有哪些?7. idea自定義快捷鍵的方法步驟8. jsp中sitemesh修改tagRule技術(shù)分享9. Django中如何使用Channels功能10. idea設(shè)置代碼格式化的方法步驟

網(wǎng)公網(wǎng)安備