C語言程序中函數(shù)的定義_第1頁
C語言程序中函數(shù)的定義_第2頁
C語言程序中函數(shù)的定義_第3頁
C語言程序中函數(shù)的定義_第4頁
C語言程序中函數(shù)的定義_第5頁
已閱讀5頁,還剩7頁未讀, 繼續(xù)免費(fèi)閱讀

下載本文檔

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

文檔簡介

第頁共頁C語言程序中函數(shù)的定義C語言程序中函數(shù)的定義C語言讀書筆記--函數(shù)先來看看函數(shù)的一般形式,嘗試寫一個(gè)加法的函數(shù):思路是這樣的:首先得有頭文件,頭文件之后就得寫主函數(shù),主函數(shù)的內(nèi)部應(yīng)該就是加法的過程,我們將所有加法的語句都拿出來組成一個(gè)函數(shù)。代碼如下:#includeintadd(inta,intb);intmain{intresult=add(3,5);printf(“sumis%d”,result);return0;}intadd(inta,intb){intsum;sum=a+b;returnsum;}這是一個(gè)最簡單的函數(shù),描繪了一個(gè)加法函數(shù)的定義和調(diào)用的過程。intadd(inta,intb)成為函數(shù)的首部。有了首部之后,就得考慮一件事情,將首部復(fù)制之后,加上一個(gè)分號,粘貼在主函數(shù)之前,作為函數(shù)的原型聲明。試想,我們在主函數(shù)里邊是不是要先定義變量result才能使用result?那么函數(shù)的道理也是一樣的,當(dāng)程序運(yùn)行到主函數(shù)中語句“intresult=add(3,5);”的時(shí)候,假如向上沒有尋找到add的定義,那么編譯器一定就會報(bào)錯(cuò)。所以要不然添加函數(shù)的原型聲明,要不然就將函數(shù)的定義直接寫在主函數(shù)之前。函數(shù)首部intadd(inta,intb)中的第一個(gè)int,即add之前的這個(gè)int稱為函數(shù)的類型。說明這個(gè)函數(shù)將要返回一個(gè)整數(shù)類型的值。這個(gè)類型可以是C語言中任何被允許的數(shù)據(jù)類型,包括void,意為無返回值類型,即這個(gè)函數(shù)不需要返回任何的值。函數(shù)首部intadd(inta,intb)中的add稱為函數(shù)的名字,簡稱函數(shù)名。函數(shù)首部intadd(inta,intb)中inta和intb稱為函數(shù)的形式參數(shù)。這里形式參數(shù)理論上可以有無窮多個(gè),當(dāng)然,現(xiàn)實(shí)情況下3-5個(gè)就已經(jīng)算是很多了;形式參數(shù)中,即使a和b都是int類型的,也要分別定義才行;形式參數(shù)可以在函數(shù)中直接使用,無須再次定義;形式參數(shù)是用來告訴調(diào)用者,你應(yīng)該給我傳遞來什么樣子的數(shù)據(jù),我好利用你給我的數(shù)據(jù)在函數(shù)中進(jìn)展計(jì)算。intadd(inta,intb){}中的{}就是函數(shù)體的內(nèi)容了。函數(shù)需要進(jìn)展的所有的操作都要放在這對大括號中。想必大家也看到了函數(shù)體中最后有一條語句是return,這條語句起到的作用就是返回函數(shù)計(jì)算的結(jié)果,在這個(gè)程序中就是將加法的結(jié)果返回給主函數(shù)。需要注意的是,函數(shù)的類型和返回值的類型必須嚴(yán)格一致!函數(shù)的定義到此為止,接下來講講函數(shù)的調(diào)用方式。只要定義好函數(shù),通過函數(shù)名(實(shí)際參數(shù)1,實(shí)際參數(shù)2,實(shí)際參數(shù)n)這種方式就可以調(diào)用函數(shù)了。例如主函數(shù)中的“intresult=add(3,5);”,就是調(diào)用了add函數(shù)。這里,3和5稱為實(shí)際參數(shù),即你終究想讓函數(shù)幫你計(jì)算哪兩個(gè)數(shù)的加法結(jié)果,你就在這個(gè)括號里邊寫哪幾個(gè)數(shù)字。必需要嚴(yán)格遵守的規(guī)定:實(shí)際參數(shù)和形式參數(shù)必須一一對應(yīng),數(shù)量應(yīng)該一樣,類型也保持一致。理解了這幾點(diǎn)之后,一個(gè)根本的函數(shù)就已經(jīng)可以寫出來了。接下來來個(gè)題目嘗試一下:輸入精度e,使用公式求π的近似值,準(zhǔn)確到最后一項(xiàng)的絕對值小于e。公式:π=1-1/3+1/5-1/7+...代碼://首先得有頭文件#include#include//后邊要使用到fabs絕對值函數(shù)//然后就是主函數(shù)了intmain(void){doublepi,e;//定義所需變量doublef_pi(doublee);//原型聲明。函數(shù)名只要符合命名規(guī)那么即可//因?yàn)橐笮∮趀,所以也將這個(gè)e傳遞過去printf(“entere:”);//輸入的提示scanf(“%lf”,-e);//double類型的e對應(yīng)%lf,記住不要缺少-printf(“pi=%lf”,f_pi(e));//函數(shù)返回的是個(gè)double類型的值,直接輸出return0;}doublef_pi(doublee)//函數(shù)首部,形參和實(shí)參一定要對應(yīng),可以重名{intdenominator,flag;doubleitem,sum;//請注意“先定義,然后賦初值再使用”的好習(xí)慣!!!flag=1;//負(fù)責(zé)變換正負(fù)符號的變量denominator=1;//分母初值為1,第一項(xiàng)的`1為1/1item=1.0;//存放每一項(xiàng)的值sum=0;while(fabs(item)》=e)//滿足條件就循環(huán){item=flag*1.0/denominator;//計(jì)算每一項(xiàng)的值。flag控制符號//1.0必須寫出小數(shù)位,否那么整項(xiàng)就變成一個(gè)整型值sum+=item;//累加flag=-flag;//符號正負(fù)切換denominator=denominator+2;//分母遞增}returnsum;//sum的類型和函數(shù)的類型必須一致}函數(shù)的定義和調(diào)用其實(shí)并不難理解,相信很多人困擾在參數(shù)的傳遞上,接下來總結(jié)一下函數(shù)參數(shù)傳遞的幾種方式:正常的參數(shù)調(diào)用,例如int、float、double等一一對應(yīng)的傳遞。無參數(shù),也無返回值。例如以下代碼就只是為了輸出一些語句。這種做法在語法上是被允許的,但是并不推薦這么寫。voidprintf{printf(“helloworld!”);}3.參數(shù)是數(shù)組的名字。我們知道數(shù)組的名字是個(gè)地址,那么假如實(shí)參是數(shù)組名的話,我們可以將形參設(shè)置成指針,指向?qū)崊鬟f過來的數(shù)組的首地址。4.參數(shù)是指針。假如實(shí)參是指針,那么形參肯定也得是指針。保持類型一致即可,然后在函數(shù)內(nèi)部再對指針進(jìn)展操作。5.參數(shù)是構(gòu)造體。假如實(shí)參是構(gòu)造體,一般來說我們使用構(gòu)造體指針來做形參比擬適宜。還是在此分割一下吧,說了這么多,可能很多人在問問什么函數(shù)定義這么費(fèi)事,還要定義函數(shù),直接都寫在main函數(shù)中多方便?非也!C語言是一個(gè)過程化的語言,C語言中的主函數(shù)其實(shí)是用來主導(dǎo)程序的進(jìn)程和數(shù)據(jù)的流動(dòng)方向的。假如將主函數(shù)寫的過于復(fù)雜,我們閱讀程序的構(gòu)造就會非常的費(fèi)力。C語言中函數(shù)回調(diào)什么是回調(diào)函數(shù)?簡而言之,回調(diào)函數(shù)就是一個(gè)通過函數(shù)指針調(diào)用的函數(shù)。假如你把函數(shù)的指針(地址)作為參數(shù)傳遞給另一個(gè)函數(shù),當(dāng)這個(gè)指針被用為調(diào)用它所指向的函數(shù)時(shí),我們就說這是回調(diào)函數(shù)。為什么要使用回調(diào)函數(shù)?因?yàn)榭梢园颜{(diào)用者與被調(diào)用者分開。調(diào)用者不關(guān)心誰是被調(diào)用者,所有它需知道的,只是存在一個(gè)具有某種特定原型、某些限制條件(如返回值為int)的被調(diào)用函數(shù)。假如想知道回調(diào)函數(shù)在實(shí)際中有什么作用,先假設(shè)有這樣一種情況,我們要編寫一個(gè)庫,它提供了某些排序算法的實(shí)現(xiàn),如冒泡排序、快速排序、shell排序、shake排序等等,但為使庫更加通用,不想在函數(shù)中嵌入排序邏輯,而讓使用者來實(shí)現(xiàn)相應(yīng)的邏輯;或者,想讓庫可用于多種數(shù)據(jù)類型(int、float、string),此時(shí),該怎么辦呢?可以使用函數(shù)指針,并進(jìn)展回調(diào)。回調(diào)可用于通知機(jī)制,例如,有時(shí)要在程序中設(shè)置一個(gè)計(jì)時(shí)器,每到一定時(shí)間,程序會得到相應(yīng)的通知,但通知機(jī)制的實(shí)現(xiàn)者對我們的程序一無所知。而此時(shí),就需有一個(gè)特定原型的函數(shù)指針,用這個(gè)指針來進(jìn)展回調(diào),來通知我們的程序事件已經(jīng)發(fā)生。下面是自己寫的一個(gè)簡單的回調(diào)函數(shù),相比其他的那些復(fù)雜的代碼,這個(gè)更容易理解:#include#includevoidperfect(intn){inti=1;intcount=0;for(i=1;i<n;i++){if(0==n%i){count+=i;}}if(count==n)printf(“%d是完數(shù)”,n);elseprintf(“%d不是完數(shù)”,n);}voidmyCallback(void(*perfect)(int),intn){perfect(n);}intmain{intn;printf(“請輸入一個(gè)正整數(shù)”);scanf(“%d”,-n);myCallback(perfect,n);return0;}C語言中的刷新和定位函數(shù)一.fflush1.fflush的原型如下:intfflush(FILE*stream);2.當(dāng)需要立即把輸出緩沖區(qū)的數(shù)據(jù)進(jìn)展物理寫入時(shí),應(yīng)該使用這個(gè)函數(shù)。例如調(diào)用fflush函數(shù)保證調(diào)試信息實(shí)際打印出來,而不是保存在緩沖區(qū)中直到以后才打印。二.定位函數(shù)1.在正常情況下,數(shù)據(jù)以線性的方式寫入,這意味著后面寫入的數(shù)據(jù)在文件中的位置是在以前所有寫入數(shù)據(jù)的后面。C同時(shí)支持隨機(jī)訪問I/O,也就是以任意順序訪問文件的不同位置。隨機(jī)訪問是通過在讀取或?qū)懭肭?,先定位到文件中需要的位置來?shí)現(xiàn)的。2.定位函數(shù)原型:1》longftell(FILE*stream);2》intfseek(FILE*steam,longoffset,intfrom);3.ftell函數(shù)返回流的當(dāng)前位置。即:下一個(gè)讀取或?qū)懭雽⒁_場的位置間隔文件起始位置的偏移量。該函數(shù)允許保存一個(gè)文件的當(dāng)前位置。1》在二進(jìn)制流中,這個(gè)值就是當(dāng)前位置間隔文件起始位置之間的字節(jié)數(shù)。2》在文本流中,這個(gè)值表示一個(gè)位置,但它并不一定準(zhǔn)確地表示當(dāng)前位置和文件起始位置之間的字符數(shù),因?yàn)橛行┫到y(tǒng)將對行末字符進(jìn)展翻譯轉(zhuǎn)換。但是,ftell函數(shù)返回的值總是可以用于fseek函數(shù)中,作為一個(gè)間隔文件起始位置的偏移量。4.fseek函數(shù)允許你一個(gè)流中定位。這個(gè)函數(shù)將改變下一個(gè)讀取或?qū)懭氩僮鞯奈恢?。它的?個(gè)參數(shù)是需要改變的流。它的第2和第3個(gè)參數(shù)標(biāo)識文件中需要定位的位置。1》試圖定位到一個(gè)文件的起始

溫馨提示

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

最新文檔

評論

0/150

提交評論