生活随笔
收集整理的這篇文章主要介紹了
C++之过载函数
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
過載函數的定義:
用同一個函數名定義不同的函數
當函數名和不同的參數搭配時函數的含義不同
過載函數的判斷標準:
函數重載至少滿足下面的一個條件:
參數個數不同
參數類型不同
參數順序不同
函數返回值不是函數重載的判斷標準
調用重載函數的準則:
將所有同名函數作為候選者
嘗試尋找可行的候選函數:
1 )精確匹配實參
2) 通過默認參數能夠匹配實參
3) 通過默認類型轉換匹配實參
匹配失敗:
1) 最終尋找到的可行候選函數不唯一,則出現二義性,編譯失敗。
2) 無法匹配所有候選者,函數未定義,編譯失敗。
注意事項:
重載函數在本質上是相互獨立的不同函數(靜態鏈編)
重載函數的函數類型是不同的
函數返回值不能作為函數重載的依據
函數重載是由函數名和參數列表決定的。
函數重載和函數指針:
當使用重載函數名對函數指針進行賦值時:
根據重載規則挑選與函數指針參數列表一致的候選者
嚴格匹配候選者的函數類型與函數指針的函數類型
void print_int(
int a)
{
printf (
"a = %d\n", a);
}void print_char(char c)
{
printf (
"c = %c\n", c);
}void print_str(char
*str)
{
printf (
"str = %s\n", str);
}// 函數重載:函數名相同,函數的參數不一樣,根據調用的時候傳的參數類型
// 決定調用哪一個函數
void printA(
int a)
{
printf (
"a = %d\n", a);
}// 參數個數不同
void printA(
int a,
int b)
{
printf (
"a = %d, b = %d\n", a, b);
}// 函數重載遇上函數默認參數可能導致 二義性的問題
void printA(
int a,
int b,
int c)
{
printf (
"a = %d, b = %d, c = %d\n", a, b, c);
}void printA(
int a, char
*str)
{
printf (
"a = %d, str = %s\n", a, str);
}void printA(char
*str,
int a)
{
printf (
"a = %d, str = %s\n", a, str);
}void printA(char c)
{
printf (
"c = %c\n", c);
}void printA(char
*str)
{
printf (
"str = %s\n", str);
}// 函數重載的規則:
1、參數個數不同
2、參數類型不同
3、參數順序不同// 函數的返回值不能作為函數重載的判定條件
//
int printA(
int a)
//{
//
//}
int main9_2()
{
int a =
10;char c =
'a';char
*str =
"hello";
// printA(
10,
20);printA(
10,
20,
30);printA(a);printA(c);printA(str);
return 0;
}
int main9_1()
{
int a =
10;char c =
'a';char
*str =
"hello";print_int(a);print_char(c);print_str(str);
return 0;
}// 對于引用,常量性不同可以作為重載的條件
int sub(int &a, int &b)
{return a - b;
}
int sub(const int &a, const int &b)
{return a - b;
}
int main9_3()
{
sub(10, 20);int a =
10;
int b =
20;
sub(a, 10);return 0;
}// 定義一個函數指針類型,有一個 void 返回值,和一個
int 類型的形參
typedef void (
*PFUNC)(
int);
int main()
{
// 當將一個重載函數賦給一個函數指針的時候// 嚴格匹配函數指針的類型PFUNC pfunc = printA;pfunc(
10);
return 0;
}
總結
以上是生活随笔為你收集整理的C++之过载函数的全部內容,希望文章能夠幫你解決所遇到的問題。
如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。