今天我們來講講函數重載。函數重載的本質為相互獨立的不同函數,在 C++ 中通過函數名和函數參數確定函數調用。是無法直接通過函數名得到重載函數的入口地址的,函數重載也必然發生在同一個作用域中。類中的成員函數也是可以進行重載的:構造函數的重載,普通成員函數的重載以及靜態成員函數的重載。那么全局函數,普通成員函數以及靜態成員函數之間可以構成重載嗎?重載函數的本質為多個不同的函數,函數名和參數列表是唯一的標識,函數重載必須發生在同一個作用域中。
下來我們以代碼為例進行分許,來回答上面提出的問題
#include <stdio.h> class Test { int i; public: Test() { printf("Test::Test()\n"); this->i = 0; } Test(int i) { printf("Test::Test(int i)\n"); this->i = i; } Test(const Test& obj) { printf("Test::Test(const Test& obj)\n"); this->i = obj.i; } static void func() { printf("void Test::func()\n"); } void func(int i) { printf("void Test::func(int i): %d\n", i); } int getI() { return i; } }; void func() { printf("void func()\n"); } void func(int i) { printf("void func(int i): %d\n", i); } int main() { Test t; // Test::Test Test t1(1); // Test::Test(int i) Test t2(t1); // Test(const Test& obj) func(); // void func() Test::func(); // void Test::func() func(2); // void func(int i), i = 2; t1.func(2); // void Test::func(int i), i = 2 t1.func(); // void Test::func() return 0; }
我們看到在類里面定義了三種構造函數,它們也構成了重載關系,還有兩個 func 函數。在全局函數中也定義了兩個重載函數,它們和類中定義的函數也能構成重載嗎?沒在一個作用域,肯定是不行的。下來我們看看編譯結果,看看分析的對不對
我們看到分析的和編譯的結果是一致的。那么重載的意義是什么呢?a> 通過函數名對函數功能進行 提示;b> 通過參數列表對函數用法進行提示;c> 擴展系統中已經存在的函數功能;下來我們通過一個示例代碼進行說明
#include <stdio.h> #include <string.h> /* char* strcpy(char* buf, const char* str, unsigned int n) { return strncpy(buf, str, n); } */ int main() { const char* s = "hello world"; char buf[8] = {0}; strcpy(buf, s); // strcpy(buf, s, sizeof(buf)-1); printf("%s\n", buf); return 0; }
我們寫了一個 strcpy 重載函數,我們先將他注釋掉。首先來調用系統中自帶的 strcpy 函數,看看編譯結果
我們看到它在運行的時候報段錯誤了。我們再來試試自己寫的重載函數呢
我們看到已經成功實現了,當然重載函數的內部是調用 strncpy 函數來實現的。但是我們只是復制,并不想考慮那么多,所以想直接用 strcpy 函數來實現這個功能,這樣就很直接了。由此可見,重載能夠擴展系統中已經存在的函數功能??!那么重載是否也能夠擴展其他更多的功能呢?比如直接用 + 號來實現復數的相加呢?我們后面接著繼續討論。通過對類中的重載函數的學習,總結如下:1、類的成員函數之間可以進行重載,重載必須發生在同一個作用域中;2、全局函數和成員函數不能構成重載關系;3、重載的意義在于擴展已經存在的功能。
歡迎大家一起來學習 C++ 語言,可以加我QQ:243343083。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。