首頁 考試吧論壇 Exam8視線 考試商城 網絡課程 模擬考試 考友錄 實用文檔 求職招聘 論文下載 | ||
![]() |
2011中考 | 2011高考 | 2012考研 | 考研培訓 | 在職研 | 自學考試 | 成人高考 | 法律碩士 | MBA考試 MPA考試 | 中科院 |
|
![]() |
四六級 | 職稱英語 | 商務英語 | 公共英語 | 托福 | 雅思 | 專四專八 | 口譯筆譯 | 博思 | GRE GMAT 新概念英語 | 成人英語三級 | 申碩英語 | 攻碩英語 | 職稱日語 | 日語學習 | 法語 | 德語 | 韓語 |
|
![]() |
計算機等級考試 | 軟件水平考試 | 職稱計算機 | 微軟認證 | 思科認證 | Oracle認證 | Linux認證 華為認證 | Java認證 |
|
![]() |
公務員 | 報關員 | 銀行從業資格 | 證券從業資格 | 期貨從業資格 | 司法考試 | 法律顧問 | 導游資格 報檢員 | 教師資格 | 社會工作者 | 外銷員 | 國際商務師 | 跟單員 | 單證員 | 物流師 | 價格鑒證師 人力資源 | 管理咨詢師考試 | 秘書資格 | 心理咨詢師考試 | 出版專業資格 | 廣告師職業水平 駕駛員 | 網絡編輯 |
|
![]() |
衛生資格 | 執業醫師 | 執業藥師 | 執業護士 | |
![]() |
會計從業資格考試(會計證) | 經濟師 | 會計職稱 | 注冊會計師 | 審計師 | 注冊稅務師 注冊資產評估師 | 高級會計師 | ACCA | 統計師 | 精算師 | 理財規劃師 | 國際內審師 |
|
![]() |
一級建造師 | 二級建造師 | 造價工程師 | 造價員 | 咨詢工程師 | 監理工程師 | 安全工程師 質量工程師 | 物業管理師 | 招標師 | 結構工程師 | 建筑師 | 房地產估價師 | 土地估價師 | 巖土師 設備監理師 | 房地產經紀人 | 投資項目管理師 | 土地登記代理人 | 環境影響評價師 | 環保工程師 城市規劃師 | 公路監理師 | 公路造價師 | 安全評價師 | 電氣工程師 | 注冊測繪師 | 注冊計量師 |
|
![]() |
繽紛校園 | 實用文檔 | 英語學習 | 作文大全 | 求職招聘 | 論文下載 | 訪談 | 游戲 |
一、棧
在說函數遞歸的時候,順便說一下棧的概念。
棧是一個后進先出的壓入(push)和彈出(pop)式數據結構。在程序運行時,系統每次向棧中壓入一個對象,然后棧指針向下移動一個位置。當系統從棧中彈出一個對象時,最近進棧的對象將被彈出。然后棧指針向上移動一個位置。程序員經常利用棧這種數據結構來處理那些最適合用后進先出邏輯來描述的編程問題。這里討論的程序中的棧在每個程序中都是存在的,它不需要程序員編寫代碼去維護,而是由運行是系統自動處理。所謂的系統自動維護,實際上就是編譯器所產生的程序代碼。盡管在源代碼中看不到它們,但程序員應該對此有所了解。
再來看看程序中的棧是如何工作的。當一個函數(調用者)調用另一個函數(被調用者)時,運行時系統將把調用者的所有實參和返回地址壓入到棧中,棧指針將移到合適的位置來容納這些數據。最后進棧的是調用者的返回地址。當被調用者開始執行時,系統把被調用者的自變量壓入到棧中,并把棧指針再向下移,以保證有足夠的空間存儲被調用者聲明的所有自變量。當調用者把實參壓入棧后,被調用者就在棧中以自變量的形式建立了形參。被調用者內部的其他自變量也是存放在棧中的。由于這些進棧操作,棧指針已經移動所有這些局部變量之下。但是被調用者記錄了它剛開始執行時的初始棧指針,以他為參考,用正或負的偏移值來訪問棧中的變量。當被調用者準備返回時,系統彈出棧中所有的自變量,這時棧指針移動了被調用者剛開始執行時的位置。接著被調用者返回,系統從棧中彈出返回地址,調用者就可以繼續執行了。當調用者繼續執行時,系統還將從棧中彈出調用者的實參,于是棧指針回到了調用發生前的位置。
可能剛開始學的人看不太懂上面的講解,棧涉及到指針問題,具體可以看看一些數據結構的書。要想學好編程語言,數據結構是一定要學的。
二、遞歸
遞歸,是函數實現的一個很重要的環節,很多程序中都或多或少的使用了遞歸函數。遞歸的意思就是函數自己調用自己本身,或者在自己函數調用的下級函數中調用自己。
遞歸之所以能實現,是因為函數的每個執行過程都在棧中有自己的形參和局部變量的拷貝,這些拷貝和函數的其他執行過程毫不相干。這種機制是當代大多數程序設計語言實現子程序結構的基礎,是使得遞歸成為可能。假定某個調用函數調用了一個被調用函數,再假定被調用函數又反過來調用了調用函數。這第二個調用就被稱為調用函數的遞歸,因為它發生在調用函數的當前執行過程運行完畢之前。而且,因為這個原先的調用函數、現在的被調用函數在棧中較低的位置有它獨立的一組參數和自變量,原先的參數和變量將不受影響,所以遞歸能正常工作。程序遍歷執行這些函數的過程就被稱為遞歸下降。
程序員需保證遞歸函數不會隨意改變靜態變量和全局變量的值,以避免在遞歸下降過程中的上層函數出錯。程序員還必須確保有一個終止條件來結束遞歸下降過程,并且返回到頂層。
相關推薦:計算機等級考試二級C語言教程匯總北京 | 天津 | 上海 | 江蘇 | 山東 |
安徽 | 浙江 | 江西 | 福建 | 深圳 |
廣東 | 河北 | 湖南 | 廣西 | 河南 |
海南 | 湖北 | 四川 | 重慶 | 云南 |
貴州 | 西藏 | 新疆 | 陜西 | 山西 |
寧夏 | 甘肅 | 青海 | 遼寧 | 吉林 |
黑龍江 | 內蒙古 |