過載函數的定義:
用同一個函數名定義不同的函數
當函數名和不同的參數搭配時函數的含義不同
過載函數的判斷標準:
函數重載至少滿足下面的一個條件:
參數個數不同
參數類型不同
參數順序不同
函數返回值不是函數重載的判斷標準
調用重載函數的準則:
將所有同名函數作為候選者
嘗試尋找可行的候選函數:
1 )精確匹配實參
2) 通過默認參數能夠匹配實參
3) 通過默認類型轉換匹配實參
匹配失敗:
1) 最終尋找到的可行候選函數不唯一,則出現二義性,編譯失敗。
2) 無法匹配所有候選者,函數未定義,編譯失敗。
注意事項:
重載函數在本質上是相互獨立的不同函數(靜態鏈編)
重載函數的函數類型是不同的
函數返回值不能作為函數重載的依據
函數重載是由函數名和參數列表決定的。
函數重載和函數指針:
當使用重載函數名對函數指針進行賦值時:
根據重載規則挑選與函數指針參數列表一致的候選者
嚴格匹配候選者的函數類型與函數指針的函數類型
#include <stdio.h>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;
}