c如何在過載函式中呼叫被過載函式

2021-03-03 21:28:38 字數 4769 閱讀 6004

1樓:匿名使用者

事先宣告過載函式

c++的基本規則:實體在使用前須先宣告。這裡也是一樣,要呼叫過載版本,須先宣告這個過載版本

c++中函式過載有啥用?

2樓:魚尾摯愛白菜

類的建構函式跟類名相同,即建構函式都同名。如果沒有函式過載機制,要想例項化不同的物件非常麻煩。

操作符過載,本質上就是函式過載,它大大豐富了已有操作符的含義,方便使用,例如「+」可用於連線字串等。

過載函式是函式的一種特殊情況,為方便使用,c++允許在同一範圍中宣告幾個功能類似的同名函式,但是這些同名函式的形式引數(指引數的個數、型別或者順序)必須不同,也就是說用同乙個運算子完成不同的運算功能。這就是過載函式。過載函式常用來實現功能類似而所處理的資料型別不同的問題。

3樓:匿名使用者

函式過載不能完全替代可變長引數......雖然函式過載可以讓你在同乙個**裡寫出print(1,2,'a');和print("a=",12);而不需要寫printf("%d%d%c",1,2,'a')和printf("%s%d","a=",12);,但代價是你需要寫無數個print函式的定義......例如這個例子裡你就要同時寫int print(const int,const int,const char)函式的定義和int print(const char*,const int)函式的定義。

儘管如果函式的引數型別唯一且引數數目在乙個很小的範圍內,那麼代價還是可以接受的(畢竟有安全性作為補償),但仍然是一種麻煩的辦法,c++11的變長引數模板給了一種既無需寫無數個函式定義又具有安全性的解決方法......

4樓:匿名使用者

過載是是c++的機制,是指具有同名但具有不同簽名(返回型別和引數)的一組函式可以同時存在,有編譯器在編譯時自動匹配合適函式的機制。而c不允許存在同名函式,如果需要同名但不同引數的呼叫,只能採用變參技術。

原因:c++ 編譯時,會根據函式名、返回值、引數給函式 重新取名為,有不用函式名稱、函式簽名的函式會有不同的不同的函式名稱,因此編譯時可以根據 這些要素找到匹配的呼叫函式;

而c, 在編譯時,只根據函式名稱找匹配的函式,因此不允許存在兩個同名函式。

作用:主要作用為,對外提供類似功能的統一介面。

如:開啟檔案,開啟電源,開啟窗戶等都是開啟動作,在c中我們必須提供 openfile()、openpower()、openwindow() 等一系列不同名稱的函式,這對外部呼叫帶來很多困難,因為我們必須記住所有的開啟函式名稱。但c++中我們只提供open(tfile& file),open(tpower& power), open(twindow& window)即可,呼叫者只需要記住有open()函式即可。

這回大大可以程式可讀性和開發效率。

5樓:祜風

1、函式過載是指在同一作用域內,可以有一組具有相同函式名,不同引數列表的函式,這組函式被稱為過載函式。

2、過載函式通常用來命名一組功能相似的函式,這樣做減少了函式名的數量,避免了名字空間的汙染,對於程式的可讀性有很大的好處。

3、具體優點說來有三點:

(1)、試想如果沒有函式過載機制,如在c中,必須要這樣去做:為這個print函式取不同的名字,如print_int、print_string。這裡還只是兩個的情況,如果是很多個的話,就需要為實現同乙個功能的函式取很多個名字,如加入列印long型、char*、各種型別的陣列等等。

這樣做很不友好!

(2)、類的建構函式跟類名相同,也就是說:建構函式都同名。如果沒有函式過載機制,要想例項化不同的物件,那是相當的麻煩!

(3)、操作符過載,本質上就是函式過載,它大大豐富了已有操作符的含義,方便使用,如+可用於連線字串等!

6樓:匿名使用者

以algorithm裡的sort函式為例,

default (1)template

void sort (randomaccessiterator first, randomaccessiterator last);

custom (2)template

void sort (randomaccessiterator first, randomaccessiterator last, ***pare ***p);

這是

上的內容,sort有兩種形式,第一種接受兩個迭代器,然後對序列排序,第二種,接受兩個迭代器和乙個自定義的比較函式來告訴sort該怎麼樣進行排序。

你可以看到,兩種形式的差別在與第二種形式多了乙個引數,為了實現這種函式,

1.要麼使用變參函式,寫乙個sort(iter,iter, ...)來將第三個引數作為變參

2.要麼使用函式過載函式,寫兩個引數不同的sort函式

3.要麼只寫三個引數的形式,然後給第三個引數乙個預設值。

這三種方法都可以實現函式名相同,引數不同的函式。你可以在標準庫里看到許多過載的函式,使用相同的函式名表示我在做同一件事,而接受引數不同,可以用於不同的情況。相比於使用變參而言,第二種和第三種技術會更簡單,更方便。

7樓:匿名使用者

也就是一種多型,比如你有了電腦就可以上網聽**看電影玩遊戲一應俱全,而不必去看電視,玩小霸王或者去影院,比喻可能不恰當不過基本這個意思。

本質是c++ oop的需要,因為c裡函式名無法重複,而c++只規定函式特徵標不能重複,也就是說c++裡同乙個函式名,比如***pare,可以比較字串與字串,整數與整數,甚至字串和整數的大小,而c裡就不得不用3個不同名的函式實現比如string_***pare,int_***pare之類,這顯然比較麻煩。另外變參在設計上並不完全安全因為沒有型別資訊,這也有悖oop設計理念。

c++中呼叫被過載函式時,通過什麼來區分被呼叫的是哪個函式

8樓:小應飛劍

編譯du器會根據你給定的實參來調zhi用過載函式中形參最匹dao配的函式:專

例如:int find(int a)屬

int find(int a,int b)int find(double a,double b=0)int find(char a)

main()

在這裡第乙個find函式呼叫int find(int a,int b)過載函式,

find(1.0)呼叫 int find(double a,double b=0)過載函式,這裡有乙個預設的形參,所以呼叫時可以給乙個變數或者兩個變數。

9樓:王玉皖

編譯器根據實bai參和形參的型別及個數du的zhi最佳匹配,自動呼叫

哪乙個dao函式。

如:void add(int a,int b)void add(double a,double b)main()

10樓:驀然

你看看過載函式是這麼定義的;

函式名同,引數不同,所以當乙個物件呼叫過載函式時,只要看引數就可以了。

呼叫的永遠是引數相同的函式;

希望你能採納

11樓:匿名使用者

通過特徵標(就是引數列表)來確定。過載函式必須是特徵標不一樣,也就是引數數目或型別不一樣

在c++,如何實現函式的過載?

12樓:董俊錕

分幾種情況,函式過載 可以根據函式的返回值型別 , 形參的個數, 通過const 關鍵字也可以實現函式過載

13樓:匿名使用者

寫多個引數不同的函式即可,保證函式名相同

14樓:匿名使用者

函式名相同,變數不同即可

c++中函式過載是什麼,能舉個例子說明是如何過載的嗎

15樓:blue丶小

函式過載:

c++允許定bai義多個du同名函式,但zhi是引數不能相同,

dao必須滿足以下條件之一版

1,引數型別不同權

2,引數數量不同 比如:

int fun(int,int);

int fun(long,int); //型別不同

int fun(int); //數量不同

這樣三個函式實現了過載,編譯器會認為是三個不同的函式ps:返回值型別不同,引數相同,是不能過載的

16樓:匿名使用者

實際上就是兩個函式,引數不同名字相同 編譯器根據引數把它們區分開,實際上最後它們的名字還是不一樣的

17樓:重新整理

就是相同作用域,相同函式名,不同的引數!根據引數來呼叫對心的函式

c++關於過載函式和析構函式呼叫

18樓:匿名使用者

這個**雖然多,但並不複雜。

就是預設構造函

數,帶引數的構造內函式,拷貝建構函式以容及析構函式,其它都是操作符過載。

預設建構函式:定義不帶引數的物件時自動呼叫;

帶引數的建構函式:定義帶引數的物件時自動呼叫;

拷貝建構函式:定義物件,物件後跟另乙個物件的引數時自動呼叫。

析構函式:如果是區域性物件,則在函式結束時,自動呼叫;全域性物件,則在整個程式結束時自動呼叫。

19樓:匿名使用者

析構函式在釋放空間的時候呼叫,過載函式在你函式呼叫的時候呼叫

20樓:艾絲

你這什麼情況?直接**就完了?

過載函式在呼叫時選擇的依據中是錯誤的

肯定是c是錯誤的 引數個數,引數型別 只要乙個不同,就能過載啊 c 中,過載函式在呼叫時選擇的依據中,是錯誤的。a引數個數b引數型別c函式名字d函式類 c錯。函式名字不可以作為依據,因為過載本身就可以使用相同的函式名,那就不能區分了,其他三個選項都可以用來區分過載時呼叫哪個函式。描敘的清楚點 不然別...

關於c中虛函式過載的問題,C 中純虛函式能過載嗎?

在派生類重新定義或者覆寫基類的過載函式,會導致繼承的名稱被遮掩。在派生類的 public 區域增加 using base func 語句可以解決。你在derive類中的func也加上了virtual導致基類函式被覆蓋,所以肯定錯了 大家都說錯了,沒說到重點。這不是什麼虛函式限制,主要原因在於函式呼叫...

C語言被呼叫函式裡棧區分配的記憶體,主呼叫函式是不能使用的

fun2.首先字串 char p表示被調函式在棧區分配乙個位元組的記憶體,p中的內容是常量區字串專 abcde 的首位址,屬函式二呼叫結束時棧區被 而p作為返回值儲存下來,常量區的 abcde 也沒有受到影響,所以可以在主函式中使用。fun3.中char str的含義是被調函式在棧區分配6個位元組記...