遞歸出現(xiàn)棧溢出stackoverflow的問題及解決
遞歸出現(xiàn)棧溢出stackoverflow
遞歸是個(gè)不斷回調(diào)方法的過程,使方法一遍遍的壓入棧中,遞歸次數(shù)多了,棧滿了也就溢出了。默認(rèn)的棧大小是1m。我也沒有很好的解決辦法,就加大棧內(nèi)存吧!
我這里就說下eclipse中測(cè)試類怎么改棧內(nèi)存大小。
右鍵測(cè)試類–》properties–》
這樣就行了
遞歸調(diào)用中棧溢出原因
那么過多的遞歸調(diào)用為什么會(huì)引起棧溢出呢?
事實(shí)上,函數(shù)調(diào)用的參數(shù)是通過??臻g來傳遞的,在調(diào)用過程中會(huì)占用線程的棧資源。
而遞歸調(diào)用,只有走到最后的結(jié)束點(diǎn)后函數(shù)才能依次退出,而未到達(dá)最后的結(jié)束點(diǎn)之前,占用的??臻g一直沒有釋放,如果遞歸調(diào)用次數(shù)過多,就可能導(dǎo)致占用的棧資源超過線程的最大值,從而導(dǎo)致棧溢出,導(dǎo)致程序的異常退出。
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
Spring Data JPA 之 JpaRepository的使用
這篇文章主要介紹了Spring Data JPA 之 JpaRepository的使用方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-02-02使用@Autowired 注入RedisTemplate報(bào)錯(cuò)的問題及解決
這篇文章主要介紹了使用@Autowired 注入RedisTemplate報(bào)錯(cuò)的問題及解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-08-08Spring cloud踩坑記錄之使用feignclient遠(yuǎn)程調(diào)用服務(wù)404的方法
這篇文章主要給大家介紹了關(guān)于Spring cloud踩坑記錄之使用feignclient遠(yuǎn)程調(diào)用服務(wù)404的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2018-11-11Java函數(shù)式編程(十二):監(jiān)控文件修改
這篇文章主要介紹了Java函數(shù)式編程(十二):監(jiān)控文件修改,本文是系列文章的第12篇,其它文章請(qǐng)參閱本文底部的相關(guān)文章,需要的朋友可以參考下2014-09-09SpringBoot一個(gè)接口多個(gè)實(shí)現(xiàn)類的調(diào)用方式總結(jié)
這篇文章主要介紹了SpringBoot一個(gè)接口多個(gè)實(shí)現(xiàn)類的調(diào)用方式,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2024-01-01Java?報(bào)錯(cuò)?java.util.ConcurrentModificationException:?null?
這篇文章主要介紹了Java?報(bào)錯(cuò)?java.util.ConcurrentModificationException:?null?的原因和解決方案,這個(gè)異常通常在多線程環(huán)境下出現(xiàn),意味著在迭代過程中,集合或者映射的結(jié)構(gòu)發(fā)生了變化,本文分享完美解決方案,需要的朋友可以參考下2023-07-07