## 一.概述
1. **重載** 在不同類型上做類似運算而又用相同名字的情況稱為重載。
2. **重載解析** C++用一種函數命名技術可以準確判斷應該調用哪個重載函數。
3. **重載依據** 返回類型、形參類型、形參個數、形參次序。
>[danger] 注意
>
>1. 返回類型不能作為單獨重載解析的依據。
>2. 不能用typedef定義的類型名來區分重載函數聲明中的參數。
4. **匹配順序(簡版)** 類型完全一致 -> 自動類型轉換 -> 用戶定義的轉換。
```c++
//若有函數原型
void fun(int);
void fun(double);
//調用函數
fun(1); //匹配void fun(int);
fun(1.0); //匹配void fun(double);
fun('a'); //匹配void fun(int);
fun(3.14f); //匹配void fun(double);
```
## [$]二.實參匹配順序
1. 精確匹配:
+ 類型完全相同。
+ 左值到右值的轉換。
+ 數組轉換成指針以及函數轉換成函數指針。
2. 向參數添加 `const` 限定符或者從實參中刪除 `const` 限定符。
3. **常量轉換** 指向變量的指針或引用轉換成指向常量的指針或引用。
4. **類型提升** 整型提升和浮點提升。
5. **其他的算術轉換、指針轉換、布爾轉換** 等隱式轉換。
6. 用戶定義的轉換
## [$]三.函數重載與域
>[info]重載函數集合中的全部函數都應在同一個域中聲明。
1. 一個聲明為局部的函數將隱藏而不是重載一個全局域中聲明的函數。
```c++
void print(const char*);
void print(double d);
int MyFunc()
{
void print(int i);
print("Hello World");//錯了!void print(const char*);聲明被隱藏了
return 0;
}
```
2. 兩個不同類的成員函數不能相互重載,為不同名字空間成員的函數不能相互重載。
3. 用 `using` 關鍵字聲明函數時會把所有的重載函數引入作用域。
4. 用 `using` 關鍵字引入一個同名的函數時,相當于重載了這個同名函數。
>[danger]如果 `using` 聲明向一個域中引入了一個函數,而該域中已經有同名函數且具有相同的參數表,則該 using 聲明就是錯誤的。
```c++
namespace demo {
void print(const char*);
void print(double);
void print(int);
}
void print(int,int);
using demo::print;
int MyFunc()
{
print(2020);//OK,demo::print(int)
print(2020,2019);//OK,print(int,int)
return 0;
}
```
## [$]四.函數重載解析
```c++
//演示代碼
void print(const char* string);
void print(double d);
void print(int i);
void print(int i,int j);
int main()
{
print(2020);//<-探討該語句的解析過程
return 0;
}
```
1. 確定函數調用考慮的重載函數的集合,確定函數調用中實參表的屬性。
>`void print(const char* string);`
>`void print(double d);`
>`void print(int i);`
>`void print(int i,int j);`
2. 從重載函數集合中選擇函數,該函數可以在(給出實參個數和類型的)情況下用調用中指定的實參進行調用。
+ **可行函數** 選出來的函數。
+ **參數夠** 可行函數的參數個數與調用的實參表中的參數數目相同,或者可行函數的參數個數多一些,但是每個多出來的參數都要有默認值。
+ **可轉換** 對于每個可行函數,調用中的實參與該函數的對應的參數類型之間必須可以進行隱式類型轉換。
+ **無匹配情況** 沒有函數與調用匹配。這個調用就是錯的。
>`void print(int i);` **可行** **精確匹配**
>`void print(double d);` **可行** **轉換后匹配**
3. 選擇與調用最匹配的函數。
+ 從實參類型到相應可行函數參數所用的轉換都被劃分等級。
+ **最佳匹配函數** 在實參的轉換上不能比別的同名函數差,而且某些實參的轉換要比別的同名函數好。
>`void print(int i);` **最佳匹配函數√** 精確匹配優于轉換后匹配
>如果還沒找到,那么你調用的東西是二義的。
- 閱讀說明
- 1.1 概述
- C++基礎
- 1.2 變量與常量
- 1.2.1 變量
- 1.2.2 字面值常量
- 字符型常量
- 數值型常量
- 1.2.3 cv限定符
- 1.3 作用域
- 1.3.1 標識符
- 1.3.2 *命名空間
- 1.3.3 作用域
- 1.3.4 可見性
- 1.4 數據類型
- 1.4.1 概述
- 1.4.2 處理類型
- 類型別名
- * auto說明符
- * decltype說明符
- 1.4.3 數組
- 1.4.4 指針
- 1.4.5 引用
- 1.5 表達式
- 1.5.1 概述
- 1.5.2 值的類別
- 1.5.3 *初始化
- 1.5.4 運算符
- 算術運算符
- 邏輯和關系運算符
- 賦值運算符
- 遞增遞減運算符
- 成員訪問運算符
- 位運算符
- 其他運算符
- 1.5.5 *常量表達式
- 1.5.6 類型轉換
- 第2章 面向過程編程
- 2.1 流程語句
- 2.1.1 條件語句
- 2.1.2 循環語句
- 2.1.3 跳轉語句
- 2.1.4 *異常處理
- 2.2 函數
- 2.2.1 概述
- 2.2.2 函數參數
- 2.2.3 內置函數
- 2.2.4 函數重載
- 2.2.5 * 匿名函數
- 2.3 存儲和生命期
- 2.3.1 生命周期與存儲區域
- 2.3.2 動態內存
- 2.4 *預處理命令
- 第3章 面向對象編程
- 3.1 概述
- 3.2 類和對象
- 3.3 成員
- 3.3.1 訪問限制
- 3.3.2 常成員
- 3.3.3 靜態成員
- 3.3.4 成員指針
- 3.3.5 this指針
- 3.4 特殊的成員函數
- 3.4.1 概述
- 3.4.2 構造函數
- 3.4.3 析構函數
- 3.4.4 拷貝語義
- 3.4.5 * 移動語義
- 3.5 友元
- 3.6 運算符重載與類型轉換
- 3.6.1 概述
- 3.6.2 重載方法
- 3.6.3 類型轉換
- 3.7 繼承與多態性
- 3.7.1 概述
- 3.7.2 派生類
- 3.7.3 子類型
- 3.7.4 虛基類
- 3.7.5 虛函數
- 3.7.6 抽象類
- 3.8 模板與泛型
- 3.8.1 概述
- 3.8.2 模板類型
- 3.8.3 *模板參數
- 3.8.4 *模板編譯
- 3.8.5 *模板推斷
- 3.8.6 *實例化與特例化
- 第4章 C++標準庫
- 4.1 概述
- 4.2 輸入輸出流
- 4.2.1 概述
- 4.2.2 *流的狀態
- 4.2.3 *常用流
- 4.2.4 *格式化I/O
- 4.2.5 *低級I/O
- 4.2.6 *隨機訪問
- 4.3 *C輸入輸出
- 4.3.1 *字符輸入輸出
- 4.3.2 *格式化輸入輸出
- 4.4 * 容器
- 4.4.1 * 概述
- 4.4.2 * 基本操作
- 4.4.3 * 順序容器
- 4.4.4 * 迭代器
- 4.4.5 * 容器適配器
- 4.5 * 泛型算法
- 4.6 * 內存管理
- 4.6.1 * 自動指針
- 4.7 * 其他設施