計算機軟件基礎課件:函數(shù)_第1頁
計算機軟件基礎課件:函數(shù)_第2頁
計算機軟件基礎課件:函數(shù)_第3頁
計算機軟件基礎課件:函數(shù)_第4頁
計算機軟件基礎課件:函數(shù)_第5頁
已閱讀5頁,還剩27頁未讀, 繼續(xù)免費閱讀

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認領

文檔簡介

函數(shù)《計算機軟件基礎》01.函數(shù)的概念02.函數(shù)的調(diào)用03.局部變量和全局變量主要內(nèi)容04.函數(shù)的遞歸調(diào)用05.函數(shù)應用舉例本章重點難點本章重點:函數(shù)的定義和調(diào)用方法;實參與形參的對應關系;調(diào)用函數(shù)時數(shù)據(jù)的傳遞方式;變量的作用域;變量的生存期;遞歸調(diào)用過程;編寫含有自定義函數(shù)、遞歸函數(shù)的程序。本章難點:調(diào)用函數(shù)時數(shù)據(jù)的傳遞方式;遞歸調(diào)用過程;編寫含有自定義函數(shù)、遞歸函數(shù)的程序。模塊化程序設計思想:

為了降低開發(fā)大規(guī)模軟件的復雜度,往往需將大規(guī)模的問題分解為若干個小問題,小問題再分解為更小的問題。模塊:一個具有獨立功能的程序段。函數(shù)是C語言中模塊化程序設計的最小單位01函數(shù)的概念函數(shù)是構(gòu)成程序的基本模塊1.函數(shù)的分類1)庫函數(shù):要用預編譯命令“#include”將指定頭文件。輸入、輸出類。例如,程序中凡是出現(xiàn)getchar()、putchar()、printf()、scanf()、gets()、puts()等函數(shù)時,在程序的開頭必須寫上預編譯命令:

#include"stdio.h"或#include<stdio.h>字符串處理類。例如,程序中出現(xiàn)strlen()、strcpy()、strcat()、strcmp()等函數(shù)時,在程序的開頭必須寫上預編譯命令:#include"string.h"或#include<string.h>數(shù)學類。例如,程序中出現(xiàn)fabs()、sqrt()、sin()、cos()等數(shù)學類函數(shù)時,在程序的開頭必須寫上預編譯命令:#include"math.h"或#include<math.h>2)用戶自定義函數(shù)函數(shù)在使用之前必須定義。函數(shù)定義的基本格式為:返回值類型函數(shù)名(類型1形式參數(shù)1,類型2形式參數(shù)2,…) /*函數(shù)頭部*/{/*花括號{}之間為函數(shù)體,花括號為函數(shù)體的定界符*/

說明部分;/*對函數(shù)體內(nèi)所有變量和即將要調(diào)用的函數(shù)作聲明*/

語句部分;/*可執(zhí)行語句序列*/}函數(shù)可以分為:有參函數(shù),無參函數(shù)。C語言不允許函數(shù)的嵌套定義。2.函數(shù)的定義02函數(shù)的調(diào)用函數(shù)的使用1.函數(shù)調(diào)用和實參一個完整的C程序可由一個主函數(shù)main()組成,或由一個主函數(shù)和若干子函數(shù)構(gòu)成。主函數(shù)可以調(diào)用子函數(shù),子函數(shù)不能調(diào)用主函數(shù)。子函數(shù)之間可以相互調(diào)用。若A函數(shù)調(diào)用B函數(shù),一般情況下,B函數(shù)在A的前面定義。若要將B放在A的后面定義,則需要在A函數(shù)體的說明部分對B進行聲明。形參和實參總的來講是一一對應的關系,具體是:①個數(shù)相等。②順序一致。③類型相符(或?qū)崊⒖梢越o形參正確的賦值)……f1();f2();……main()……f3()………………f1()f2()…………f3()2.函數(shù)調(diào)用和返回值1)無返回值函數(shù)的調(diào)用若函數(shù)中return語句后面無表達式或者函數(shù)無return語句,這時函數(shù)沒有返回值。沒有返回值的函數(shù),其類型定義空類型,用類型名void表示。intmain(){voidmax(int,int); …max(a,b); /*無返回值函數(shù)調(diào)用*/return0;} /*無返回值函數(shù)定義*/voidmax(intx,inty){}對函數(shù)max的調(diào)用聲明兩個形式參數(shù)x,y兩個實際參數(shù)a,b2)有返回值函數(shù)的調(diào)用若函數(shù)中有“return(表達式);”語句或“return表達式;”語句,則該函數(shù)一定有返回值。return后面表達式值的類型應以所在函數(shù)返回值類型為準。當函數(shù)類型為int時,可以不寫,系統(tǒng)默認為int。intmain(){intmax(int,int); …c=max(a,b);/*有返回值函數(shù)調(diào)用*/return0;} /*無返回值函數(shù)定義*/intmax(intx,inty){…returnz;}對函數(shù)max的調(diào)用聲明兩個形式參數(shù)x,y兩個實際參數(shù)a,b返回值z3.函數(shù)調(diào)用時的數(shù)據(jù)傳遞數(shù)據(jù)傳遞方式有4種:單向值傳遞方式地址傳遞方式返回值傳遞方式全局變量傳遞方式1)單向值傳遞方式單向值傳遞方式是調(diào)用函數(shù)時,將實參值計算出來賦給對應的形參,即數(shù)據(jù)只能從實參單向傳給形參。單向值傳遞的調(diào)用過程①形參和實參各占一個獨立的存儲空間。②形參的存儲空間是在函數(shù)調(diào)用時才分配的,調(diào)用前是不占存儲的。調(diào)用開始,系統(tǒng)為形參開辟一個臨時存儲區(qū),然后將各實參值傳給對應的形參,這時形參就得到了實參的值。③函數(shù)執(zhí)行完返回時,形參的臨時存儲區(qū)被回收。單向值傳遞調(diào)用的特點①函數(shù)中對形參的操作不會影響到主調(diào)函數(shù)中的實參。②單向值傳遞時實參可以是常數(shù)、已有值的變量和表達式,而形參一般是變量。2)地址傳遞方式在函數(shù)調(diào)用中,把實參數(shù)組的起始地址傳給形參,這樣兩個數(shù)組就共占同一段內(nèi)存空間(形參數(shù)組是不分配內(nèi)存的)。傳遞了數(shù)組的首地址后,被調(diào)函數(shù)就能夠準確的知道該數(shù)組的存儲位置。形參數(shù)組中各元素值如發(fā)生變化會使這個實參數(shù)組的值同時發(fā)生變化。也稱為雙向傳遞,即不僅能將主調(diào)函數(shù)中的數(shù)據(jù)帶到被調(diào)函數(shù),而且能把被調(diào)函數(shù)變化了的數(shù)據(jù)帶回主調(diào)函數(shù)。注意:

①以一維數(shù)組名作參數(shù)時,實參數(shù)組必須定義為具有確定長度的數(shù)組,而形參可以不定義長度。

②使用形參數(shù)組時,其下標不要超過實參數(shù)組的長度。

③實參數(shù)組與相應的形參數(shù)組類型應一致。03局部變量和全局變量作用域:變量在什么范圍內(nèi)有效根據(jù)作用域不同,分為:局部變量全局變量1.局部變量在函數(shù)內(nèi)定義,只在本函數(shù)范圍內(nèi)有效的變量。局部變量只是當其所在的函數(shù)被調(diào)用時才具有確定的存儲空間主函數(shù)main中定義的局部變量只在主函數(shù)中有效,主函數(shù)不能使用其他函數(shù)中定義的局部變量。不同函數(shù)中可以使用相同的變量名,但它們有各自的作用域,互不干擾。作用:增強了函數(shù)模塊的獨立性。如例4-7。2.全局變量在函數(shù)外部定義的量,可以為程序中各個函數(shù)所引用,其作用域是整個程序。從程序運行開始起就占據(jù)內(nèi)存,僅在程序結(jié)束時才將其釋放。優(yōu)點:使函數(shù)之間的數(shù)據(jù)交換更容易,也更高效。缺點:全局變量在程序的執(zhí)行過程中一直占用存儲空間,降低了空間利用率。各函數(shù)執(zhí)行時都可能改變?nèi)肿兞康闹?,程序易出錯,降低了程序的可讀性。全局變量的作用牽制了各個函數(shù),降低了各函數(shù)之間的相對獨立性。建議程序設計過程中盡量不使用全局變量。如例4-9。3.變量的生存期變量的生存期是指變量從生產(chǎn)到被撤銷的時間段,實際上就是變量占用內(nèi)存的時間。

變量的生存期是由變量的存儲類型聲明的。其一般聲明方式如下:存儲類型數(shù)據(jù)類型變量名表;C語言中提供的存儲類型主要有四種:auto(自動變量)register(寄存器變量)static(靜態(tài)變量)extern(外部變量)1)用auto聲明的自動變量變量定義時缺少存儲類型說明則系統(tǒng)默認為自動變量。例如:autointa=2,b=3;等價于:inta=2,b=3;特點:函數(shù)調(diào)用結(jié)束,該種變量即被釋放,屬于動態(tài)存儲方式。2)用register聲明的寄存器變量寄存器是CPU內(nèi)部的一種容量有限但速度極快的存儲器。

寄存器的存取速度高于內(nèi)存的存取速度?,F(xiàn)代編譯程序能自動優(yōu)化程序,自動把普通變量優(yōu)化為寄存器變量,并且可以忽略用戶的register指定,所以一般無需特別聲明變量為寄存器變量。3)用extern聲明的外部變量如果在所有函數(shù)之外定義的變量沒有指定其存儲類別,那么它就是一個外部變量。外部變量是全局變量。

沒有顯示初始化的外部變量由編譯程序自動初始化為0。file2.cexterna;print(){……}modify(){……c=a*2;}file1.cinsert(){

externa;……

}inta;query(){……}/*在定義點之前*//*在其他文件中*/4)用static聲明的靜態(tài)變量這種變量的值在函數(shù)結(jié)束后占用的存儲空間不回收,在下一次調(diào)用該函數(shù)時,變量的值仍保持上一次退出函數(shù)前所擁有的值。優(yōu)點:提高了程序的運行效率。缺點:對于相同的輸入?yún)?shù)輸出不同的結(jié)果,因此建議盡量少用靜態(tài)局部變。C語言規(guī)定在定義局部靜態(tài)變量時,如不賦初值,自動賦初值,數(shù)值型變量則賦0值,字符型變量賦空字符。04函數(shù)的遞歸調(diào)用調(diào)用一個函數(shù)的過程中又出現(xiàn)直接或間接地調(diào)用該函數(shù)本身,稱為函數(shù)的遞歸調(diào)用。函數(shù)是可以嵌套調(diào)用的,如下圖所示,main可以調(diào)用函數(shù)A,函數(shù)A繼續(xù)調(diào)用函數(shù)B。main函數(shù){............調(diào)用函數(shù)A;............}函數(shù)A{............調(diào)用函數(shù)B;............}函數(shù)B{..............................}調(diào)用返回調(diào)用返回求n的階乘n!

longfactn(4){longfac;......fac=4*factn(3);returnfac;}返回6longfactn(3){longfac;......fac=3*factn(2);returnfac;}返回2longfactn(2){longfac;......fac=2*factn(1);returnfac;}返回1longfactn(1){longfac;if(n==1)return1;......}intmain(){…w=factn(4);printf(“4!=%1d\n”,w);return0;}返回24以求4!為例,遞歸調(diào)用執(zhí)行過程如下:當?main?函數(shù)開始調(diào)用?factn(4)?時,開始遞歸過程,依次調(diào)用?factn(3)?,?factn(2?),?factn(1)?。這個過程就是函數(shù)的嵌套調(diào)用,比較容易理解。longfactn(4){longfac;......fac=4*factn(3);returnfac;}返回6longfactn(3){longfac;......fac=3*factn(2);returnfac;}返回2longfactn(2){longfac;......fac=2*factn(1);returnfac;}返回1longfactn(1){longfac;if(n==1)return1;......}intmain(){…w=factn(4);printf(“4!=%1d\n”,w);return0;}返回24以求4!為例,遞歸調(diào)用執(zhí)行過程如下:最重要的是當執(zhí)行?factn(1)?時,因為滿足?n==1?,執(zhí)行?return(1)?,遞歸調(diào)用被終止,但程序沒有結(jié)束。它將返回值1傳遞給調(diào)用它的?factn(2)?,以此類推,最終?factn(4)?將計算結(jié)果24返回給?main?函數(shù),得到期望的結(jié)果。longfactn(4){longfac;......fac=4*factn(3);returnfac;}返回6longfactn(3){longfac;......fac=3*factn(2);returnfac;}返回2longfactn(2){longfac;......fac=2*factn(1);returnfac;}返回1longfactn(1){longfac;if(n==1)return1;......}intmain(){…w=factn(4);printf(“4!=%1d\n”,w);return0;}返回24以求4!為例,遞歸調(diào)用執(zhí)行過程如下:總而言之,調(diào)用的過程容易被理解,但是初學者往往容易忽視返回的過程。遞歸優(yōu)點:思路簡潔清晰(因為具體的實施過程不需要編程者

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責。
  • 6. 下載文件中如有侵權(quán)或不適當內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論