詳解C語言初階之函數(shù)
1.main函數(shù)
第一個函數(shù)是我們的main函數(shù),它無處不在,main函數(shù)被稱之為我們的入口函數(shù),程序在運行時,從main函數(shù)進(jìn)入,從main函數(shù)出來,main函數(shù)其實就是整個程序功能的集合,所有的功能必須被包含在main里面才可以被運行(預(yù)處理命令,宏定義,全局變量什么的當(dāng)然要優(yōu)先處理,再次不討論這些)。我們看個例子吧

上圖中,一個很簡單的打印,卻發(fā)現(xiàn)main函數(shù)之外的打印出現(xiàn)了錯誤,由此說明main的重要型。
說白了,函數(shù)就是一個個功能的集合,內(nèi)部也是一串串代碼組成的程序,是程序的基本單元,又被叫作子程序,我們將函數(shù)分為庫函數(shù)和自定義函數(shù),再次我們主要了解自定義函數(shù)。
2.自定義函數(shù)
所謂自定義函數(shù),就是我們自己寫的函數(shù),我們自己設(shè)置了他們的功能,將他們進(jìn)行封裝,在某些時候進(jìn)行調(diào)用。如:

在這里,我們把一個簡單地加法運算進(jìn)行了封裝。只要在main函數(shù)里調(diào)用這個定義函數(shù),我們即可實現(xiàn)加法的功能。
那么,有人問了,我們?yōu)槭裁捶且獙懸粋€函數(shù)呢,看起來就很麻煩,直接寫到main函數(shù)里不就行了嗎?
2.1 函數(shù)的的封裝和面向過程的思維
實際上,我們在應(yīng)用中不可能寫如此簡單的小程序,我們會寫很長的代碼(比如我們在剛剛的程序中加上減法、除法、乘法、求余、求次方等等),很多的功能,如果我們?nèi)珜懺趍ain函數(shù)里,代碼的可讀性就會變得極差,而且main函數(shù)不僅會變得十分冗長,對于代碼的調(diào)試和修改以及后期維護(hù)都難以進(jìn)行。因此,我們把所有功能都進(jìn)行封裝打包,扔到我們自己的一個函數(shù)里,每一個函數(shù)都有想對應(yīng)的功能(一般來說,我們要盡量加大自定義函數(shù)的獨立性,方便函數(shù)的封裝和后期維護(hù)),如此一來,我們就有了業(yè)務(wù)邏輯(想要程序?qū)崿F(xiàn)的功能,如加法,就在main函數(shù)里面調(diào)用Add)和功能邏輯(再對Add進(jìn)行定義),main函數(shù)就變得十分簡潔明了,只需要用到哪些功能時,直接調(diào)用就行了,我們將功能邏輯的功能稱之為解耦。在編寫代碼時,我們要首先知道我們想要實現(xiàn)什么功能,在主函數(shù)里對某一個可以實現(xiàn)該功能的函數(shù)先進(jìn)行調(diào)用,等主函數(shù)完備后,再講我們封裝的功能進(jìn)行定義,以配合我們的調(diào)用。我們把這種編程思維,稱之為面向過程,即先明白要實現(xiàn)什么功能(對象)后,還需要對每一個功能進(jìn)行具體構(gòu)建(對象的構(gòu)建),而不是直接調(diào)用該功能,比如我們要木材,就必須要自己種木頭,澆花施肥,然后再取用,而不能直接去木材市場買,我們需要過程。
3.函數(shù)的組成
函數(shù)需要有定義之后才能調(diào)用,某些時候還需要聲明(我們先不談聲明)
函數(shù)的定義由四部分組成:返回值(也叫函數(shù)類型)、函數(shù)名 、函數(shù)體 、形參
函數(shù)的調(diào)用由三部分組成:返回值、函數(shù)名、形參
3.1函數(shù)的命名法
為了增加可讀性,和減少維護(hù)成本,我們通常把函數(shù)的命名方法定為見名知意,將名字按照大駝峰法進(jìn)行命名(如加法及 Add,我的打印及 MyPrint)函數(shù)名以英文單詞或者英文單詞的簡寫構(gòu)成,每個單詞的第一個字母大寫。
3.2函數(shù)的返回值
函數(shù)的返回值類型有int、char、double等各種類型,具體看你需要的功能。
如在剛剛的Add中,我們需要Add函數(shù)返回x和y的和(即返回一個整型,便于函數(shù)值的接收),因此我們需要在Add前面加int,如此我們便可以用int ret來接收函數(shù)值。
3.2.1void類型
在各種函數(shù)的返回值中,有一個奇怪卻又常用的類型,叫作void(也就是空的意思),其實,它就是個占位子的,啥都不返回(我就站這兒,告訴別人這里這個座有人了)

如圖所示,我們把printf放在了Add里面,如此來,我們就不需要接收Add的返回值來進(jìn)行打印了,這個函數(shù)本身就有了打印的功能,因此我們把返回值(也就是函數(shù)類型寫為void),也就是沒有返回值。比如main函數(shù)也可以直接void main。
補充:
1.通常情況下,我們并不建議這么寫,因為我們需要函數(shù)功能的獨立性,減少多余的聯(lián)系,后面大家會慢慢理解
2.main 函數(shù)建議以int作為返回值,代碼規(guī)范是一個優(yōu)秀程序員的基本素養(yǎng)。特立獨行并不會讓你變得優(yōu)秀,優(yōu)秀的代碼是大多數(shù)人都能明白的代碼
3.既然返回值已經(jīng)為空,那我直接不寫不行嗎,為什么還要寫一個void呢?
注意:函數(shù)默認(rèn)是有返回值,不寫的話會進(jìn)行強制返回(強制類型轉(zhuǎn)換為整型),默認(rèn)返回值為int,有了void,就不會有其他返回值類型來占座
3.3形參與實參
函數(shù)調(diào)用括號里的參數(shù)叫作實參,函數(shù)定義括號里的參數(shù)叫作形參。
實參就是試試在在的真是的數(shù)據(jù),就如同一張桌子,你砸了它一角,那這張桌子一角就真的沒了。
形參本質(zhì)上是對實參的臨時拷貝(程序從主函數(shù)中運行到函數(shù)的調(diào)用時,就會自動在主函數(shù)前尋找該函數(shù)的定義,若發(fā)現(xiàn)定義,就會發(fā)生形參實例化,即將實參拷貝到形參里),還是一張桌子,發(fā)生形參實例化(臨時拷貝)之后,就變成了兩張桌子,現(xiàn)在你砸了第二張桌子,那第一張桌子依舊完好無損。而不管第二張桌子是是否損傷,只要出了它所在的代碼塊,它就會被銷毀掉,而不能被其他函數(shù)繼續(xù)使用,所以我們稱之為臨時拷貝。

上圖,我們發(fā)現(xiàn),在函數(shù)定義內(nèi)拷貝參數(shù)改變的值并不會影響原值。這種參數(shù)傳遞方式我們叫做傳值。
總結(jié)
本篇文章就到這里了,希望能夠給你帶來幫助,也希望您能夠多多關(guān)注腳本之家的更多內(nèi)容!
相關(guān)文章
淺談c++ 字符類型總結(jié)區(qū)別wchar_t,char,WCHAR
下面小編就為大家?guī)硪黄獪\談c++ 字符類型總結(jié)區(qū)別wchar_t,char,WCHAR。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-03-03
仿現(xiàn)代C++智能指針實現(xiàn)引用計數(shù)
這篇文章主要為大家詳細(xì)介紹了如何仿現(xiàn)代C++智能指針實現(xiàn)引用計數(shù),文中的示例代碼講解詳細(xì),具有一定的借鑒價值,有需要的小伙伴可以了解下2024-03-03
C語言用fun函數(shù)實現(xiàn)兩個數(shù)的交換方式
這篇文章主要介紹了C語言用fun函數(shù)實現(xiàn)兩個數(shù)的交換方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-12-12
C語言實現(xiàn)文件內(nèi)容按行隨機排列的算法示例
這篇文章主要介紹了C語言實現(xiàn)文件內(nèi)容按行隨機排列的算法,涉及C語言字符串、數(shù)組遍歷與隨機數(shù)相關(guān)算法實現(xiàn)技巧,需要的朋友可以參考下2017-09-09
C語言數(shù)據(jù)結(jié)構(gòu)之線索二叉樹及其遍歷
這篇文章主要介紹了C語言數(shù)據(jù)結(jié)構(gòu)之線索二叉樹及其遍歷的相關(guān)資料,為了加快查找節(jié)點的前驅(qū)和后繼。對二叉樹的線索化就是對二叉樹進(jìn)行一次遍歷,在遍歷的過程中檢測節(jié)點的左右指針是否為空,如果是空,則將他們改為指向前驅(qū)和后繼節(jié)點的線索,需要的朋友可以參考下2017-08-08
C語言?使用qsort函數(shù)來進(jìn)行快速排序
排序方法有很多種:選擇排序,冒泡排序,歸并排序,快速排序等。?看名字都知道快速排序是目前公認(rèn)的一種比較好的排序算法。因為他速度很快,所以系統(tǒng)也在庫里實現(xiàn)這個算法,便于我們的使用。?這就是qsort函數(shù)2022-02-02

