1樓:du瓶邪
過載函式
過載,英文為overloading,大概就是很多個的意思。
舉個例子,比如,我需要個函式。
取2個int的最大值。很容易,函式介面應該是(1) int max(int a, int b);
那更進一步,我取3個 int 的最大值呢,介面可以定義為(2) int max(int a, int b, int c);
對比 函式(1), (2), 的名字,是一樣的,都叫 max,就只有引數的個數不同。這是函式過載。
那現在,我需要取兩個float的最大值呢,介面也可以定義為(3) float max(float a, float b);
對比 函式(1),(3), 名字也是一樣的,叫max。引數個數也是一樣的。不過引數的型別不同。這也是函式過載。
2樓:
函式的過載,主要是說,當你傳進對應的引數的時候,呼叫的對應的函式。也就是樓上所說的多型。比如一個籃子可以裝蘋果8個或者裝梨子4個。
當你告訴籃子說我要裝蘋果,它就給你返回一個說我能裝8個。你又告訴籃子說我要裝梨子,它就給你返回一個4個。就是這個意思。
3樓:歪歪
函式過載是指在同一作用域內,可以有一組具有相同函式名,不同引數列表的函式,這組函式被稱為過載函式。過載函式通常用來命名一組功能相似的函式,這樣做減少了函式名的數量,避免了名字空間的汙染,對於程式的可讀性有很大的好處。
1.2、為什麼需要函式過載(why)?試想如果沒有函式過載機制,如在c中,你必須要這樣去做:
為這個print函式取不同的名字,如print_int、print_string。這裡還只是兩個的情況,如果是很多個的話,就需要為實現同一個功能的函式取很多個名字,如加入列印long型、char*、各種型別的陣列等等。這樣做很不友好!
類的建構函式跟類名相同,也就是說:建構函式都同名。如果沒有函式過載機制,要想例項化不同的物件,那是相當的麻煩!
操作符過載,本質上就是函式過載,它大大豐富了已有操作符的含義,方便使用,如+可用於連線字串等!
我們在開瓶瓶罐罐的時候,經常會遭遇因各種瓶口規格不同而找不到合適的工具的尷尬。所以有時候就為了開個瓶,家裡要備多種規格的開瓶器。同樣是開個瓶子嘛,何必這麼麻煩?
於是有人發明了多功能開瓶器,不管啤酒瓶汽水瓶還是軟木塞的紅酒瓶都能輕鬆開啟。
然而開瓶器的問題也會發生到程式設計中。比如我們要編寫一個函式來求一個數的絕對值,然而整數、浮點型數、雙精度型數都有絕對值,但為它們編寫的函式返回值型別卻是各不相同的。比如:
int iabs(int a);
float fabs(float a);
double dabs(double a);
這樣是不是有點備了多種開瓶器的感覺?我們能不能在程式設計中也做一個多功能的開瓶器,把所有資料型別的求絕對值都交給abs這一個函式呢?
在c++中,我們也能夠把具有相同功能的函式整合到一個函式上,而不必去寫好多個函式名不同的函式,這叫做函式的重(音chóng)載(overload)。過載的本質是多個函式共用同一個函式名。
我們先來看一個函式過載的例項:(程式6.3)
#include "iostream.h"
int abs(int a);//當引數為整型資料時的函式原型
float abs(float a);//當引數為浮點型資料時的函式原型
double abs(double a);//當引數為雙精度型資料時的函式原型
int main()
int abs(int a)//函式定義
float abs(float a)
double abs(double a)
執行結果:
int abs
int abs
a=5b=3
float abs
float abs
c=2.4
d=8.4
double abs
double abs
e=3e-009
f=3e+006
執行結果表明,abs函式果然能夠處理三種不同資料型別的資料了。那麼我們怎樣才能自己造一個「多功能工具」呢?
其實要編寫一個過載函式並不是很麻煩。首先,我們要告訴電腦,同一個函式名存在了多種定義,所以,我們要給同一個函式名寫上多種函式原型(如程式6.3的第二到第四行);其次,我們要對應這些函式原型,分別寫上這些函式的定義(如程式6.
3的主函式體之後,對三個abs函式的定義)。
然而電腦又是如何來識別這些使用在不同環境下的「工具」的呢?
在日常生活中使用到多功能工具,如果我們不知道具體應該使用哪個工具,我們會把每個工具放上去試一試,如果只有唯一一個工具適合,那麼我們就毫無疑問地能夠確定就是使用它了。但是如果出現了兩個或者兩個以上工具都能適合,我們就分不清到底應該使用哪個是正確的了。
電腦的做法和我們是類似的。電腦是依靠函式宣告時參數列中引數個數、各引數的資料型別和順序來判斷到底要執行哪個函式的。因此,當過載函式參數列完全相同的時候,電腦便無法判斷應該執行哪個函式,於是程式就出錯了。
我們瞭解了電腦是如何識別過載函式以後,發現要編寫一個過載函式還是需要注意一些地方的,那就是:在過載函式中,任意兩個函式的參數列中的引數個數、各引數的資料型別和順序不能完全一樣。例如int func(int a,char b)和float func(int c,char d)就不能過載,因為它們的引數個數、各引數的型別和順序完全一樣,即使形參名不同、返回值型別不同也是無濟於事的。
在呼叫一個過載函式時,可能會發生找不到一個完全合適的函式。這時候,就需要進行資料型別的轉換。由於這種方法可能導致資料丟失或資料型別不嚴格符合,且在充分考慮問題後,這種情況是可以儘量避免的,所以這裡不再就這個問題論述。
有興趣的讀者可以查閱其他c++的參考資料。
從某種意義上說,過載函式是方便了函式的使用者。在前一節我們知道,如果完成了所有函式的編寫,那麼完成一個程式就像搭積木一樣簡單了。然而如果功能相似名字卻不同的函式太多,那麼多「積木」搭起來也未必簡單。
當函式的編寫者充分考慮了不同情況下應該執行稍有不同的函式,函式的使用者就不必為這些小細節而煩惱了。不過過載函式的函式名還是應該符合其功能,如果把功能完全不同的函式過載,那麼就大大影響了程式的可讀性。
4樓:匿名使用者
這是函式的過載,能夠實現多型。根據引數的型別分別呼叫不同的函式
5樓:朱同路口
函式的過載,函式名字雖相同,但是功能缺失不同。可以根據需要傳進去的引數做到函式功能不同。
6樓:匿名使用者
應該一個是建構函式,一個是成員函式
c++中函式過載有什麼用?
7樓:魚尾摯愛白菜
類的建構函式跟類名相同,即建構函式都同名。如果沒有函式過載機制,要想例項化不同的物件非常麻煩。
操作符過載,本質上就是函式過載,它大大豐富了已有操作符的含義,方便使用,例如「+」可用於連線字串等。
過載函式是函式的一種特殊情況,為方便使用,c++允許在同一範圍中宣告幾個功能類似的同名函式,但是這些同名函式的形式引數(指引數的個數、型別或者順序)必須不同,也就是說用同一個運算子完成不同的運算功能。這就是過載函式。過載函式常用來實現功能類似而所處理的資料型別不同的問題。
8樓:卷軒諸雲澤
1、函式過載是指在同一作用域內,可以有一組具有相同函式名,不同引數列表的函式,這組函式被稱為過載函式。
2、過載函式通常用來命名一組功能相似的函式,這樣做減少了函式名的數量,避免了名字空間的汙染,對於程式的可讀性有很大的好處。
3、具體優點說來有三點:
(1)、試想如果沒有函式過載機制,如在c中,必須要這樣去做:為這個print函式取不同的名字,如print_int、print_string。這裡還只是兩個的情況,如果是很多個的話,就需要為實現同一個功能的函式取很多個名字,如加入列印long型、char*、各種型別的陣列等等。
這樣做很不友好!
(2)、類的建構函式跟類名相同,也就是說:建構函式都同名。如果沒有函式過載機制,要想例項化不同的物件,那是相當的麻煩!
(3)、操作符過載,本質上就是函式過載,它大大豐富了已有操作符的含義,方便使用,如+可用於連線字串等!
9樓:桐軍夷婉麗
以algorithm裡的sort函式為例,default
(1)template
void
sort
(randomaccessiteratorfirst,
randomaccessiterator
last);
custom
(2)template
void
sort
(randomaccessiteratorfirst,
randomaccessiterator
last,
***pare
***p);
這是http://****cplusplus.
***/reference/algorithm/sort/上的內容,sort有兩種形式,第一種接受兩個迭代器,然後對序列排序,第二種,接受兩個迭代器和一個自定義的比較函式來告訴sort該怎麼樣進行排序。
你可以看到,兩種形式的差別在與第二種形式多了一個引數,為了實現這種函式,
1.要麼使用變參函式,寫一個sort(iter,iter,...)來將第三個引數作為變參
2.要麼使用函式過載函式,寫兩個引數不同的sort函式3.要麼只寫三個引數的形式,然後給第三個引數一個預設值。
這三種方法都可以實現函式名相同,引數不同的函式。你可以在標準庫裡看到許多過載的函式,使用相同的函式名錶示我在做同一件事,而接受引數不同,可以用於不同的情況。相比於使用變參而言,第二種和第三種技術會更簡單,更方便。
10樓:匿名使用者
過載是是c++的機制,是指具有同名但具有不同簽名(返回型別和引數)的一組函式可以同時存在,有編譯器在編譯時自動匹配合適函式的機制。而c不允許存在同名函式,如果需要同名但不同引數的呼叫,只能採用變參技術。
原因:c++ 編譯時,會根據函式名、返回值、引數給函式 重新取名為,有不用函式名稱、函式簽名的函式會有不同的不同的函式名稱,因此編譯時可以根據 這些要素找到匹配的呼叫函式;
而c, 在編譯時,只根據函式名稱找匹配的函式,因此不允許存在兩個同名函式。
作用:主要作用為,對外提供類似功能的統一介面。
如:開啟檔案,開啟電源,開啟窗戶等都是開啟動作,在c中我們必須提供 openfile()、openpower()、openwindow() 等一系列不同名稱的函式,這對外部呼叫帶來很多困難,因為我們必須記住所有的開啟函式名稱。但c++中我們只提供open(tfile& file),open(tpower& power), open(twindow& window)即可,呼叫者只需要記住有open()函式即可。
這回大大可以程式可讀性和開發效率。
c函式過載,c中函式過載的原則是什麼啊
c語言沒有函式過載一說,c 有。c 過載 只要函式名相同,引數個數或型別不同就構成過載 c 中函式過載的原則是什麼啊?函式過載的定義 函式過載是指在同一作用域內,可以有一組具有相同函式名,不同引數列表的函式,這組函式被稱為過載函式。所以原則就是相同的函式名,不同的引數列表。返回值不能作為過載依據。函...
c中行內函數是什麼意思C中行內函數是什麼意思?
行內函數具有一般函式的特性,它與一般函式所不同之處只在於函式呼叫的處理。一般函式進行呼叫時,要將程式執行權轉到被呼叫函式中,然後再返回到呼叫它的函式中 而行內函數在呼叫時,是將呼叫表示式用行內函數體來替換。在使用行內函數時,應注意如下幾點 1.在行內函數內不允許用迴圈語句和開關語句。如果行內函數有這...
c 中「!x」是什麼意思,在c 中符號 x是什麼意思
是c 的邏 bai輯運算子,意du思是 非 zhix的意思 對於一個dao命題x如果將專其否定,就得到一個新屬命題,記作 x,讀作 非x 運算子是說明特定操作的符號 它是構造c語言表示式的工具 c語言的運算異常豐富,除了控制語句和輸入輸出以外的幾乎所有的基本操作都作為運算子處理。擴充套件資料 c語言...