python防止棧溢出的實(shí)例講解
使用遞歸函數(shù)的優(yōu)點(diǎ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. Python基于requests庫爬取網(wǎng)站信息2. 一文帶你徹底理解Java序列化和反序列化3. JS中6個(gè)對(duì)象數(shù)組去重的方法4. Python使用Selenium自動(dòng)進(jìn)行百度搜索的實(shí)現(xiàn)5. vscode運(yùn)行php報(bào)錯(cuò)php?not?found解決辦法6. python中文本字符處理的簡單方法記錄7. PHP laravel實(shí)現(xiàn)導(dǎo)出PDF功能8. Java commons-httpclient如果實(shí)現(xiàn)get及post請(qǐng)求9. PHP利用curl發(fā)送HTTP請(qǐng)求的實(shí)例代碼10. 資深程序員:給Python軟件開發(fā)測(cè)試的25個(gè)忠告!

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