
??一、缺省參數(shù)
??1、基本概念
缺省參數(shù)是聲明或定義函數(shù)時為函數(shù)的參數(shù)指定一個缺省值。
在調(diào)用該函數(shù)時,如果沒有指定實參則采用該形參的缺省值,否則使用指定的實參。
??舉個栗子??
//缺省參數(shù)
void Func(int a = 1)
{
cout << a << endl;
}
int main()
{
Func(10);
Func();
return 0;
}
??注意:缺省值(函數(shù)形參的默認值)不能同時在函數(shù)聲明和函數(shù)定義中給出(缺省參數(shù)不能在函數(shù)聲明和定義中同時出現(xiàn));
??注意:缺省值必須是常量或者全局變量。
??2、缺省參數(shù)的分類
??全缺省參數(shù)
??全缺省參數(shù):每個形參都指定缺省值
??舉個栗子??
//全缺省參數(shù)
void Func(int a = 10, int b = 20, int c = 30)
{
cout << "a = " << a << endl;
cout << "b = " << b << endl;
cout << "c = " << c << endl << endl;
}
int main()
{
Func();
//顯示傳參,從左往右顯示傳參
Func(1);
Func(1,2);
Func(1, 2, 3);
return 0;
}
??半缺省參數(shù)
??半缺省參數(shù):為部分形參指定缺省值
??舉個栗子??
//半缺省參數(shù)
void Func(int a, int b = 10, int c = 20)
{
cout << "a = " << a << endl;
cout << "b = " << b << endl;
cout << "c = " << c << endl << endl;
}
int main()
{
Func(1);
Func(1,2);
Func(1, 2, 3);
return 0;
}
??注意:半缺省參數(shù)必須從右往左依次來給出,不能間隔著給
?下面這種情形是不允許的??
void Func(int a = 10, int b, int c = 20)
{
cout << "a = " << a << endl;
cout << "b = " << b << endl;
cout << "c = " << c << endl << endl;
}
??缺省參數(shù)實用案例
假如要實現(xiàn)一個棧的結(jié)構(gòu),我們不知道要入棧插入多少個數(shù)據(jù),所以不知道初始化開辟多少內(nèi)存空間合適,給多了浪費,給少了不夠用,這時我們就可以使用缺省參數(shù)
??請看演示代碼??
Stack.h
#include<stdlib.h>
namespace N1
{
typedef struct Stack
{
int* a;
int top;
int capacity;
}ST;
//不允許聲明和定義同時給缺省參數(shù)
//聲明給,定義不給
void StackInit(ST* ps, int N = 4)
{
ps->a = (int*)malloc(sizeof(int) * N);
ps->top = 0;
ps->capacity = 0;
}
Test.cpp
#include "Stack.h"
int main()
{
N1::ST st1;
StackInit(&st1, 10);//知道10個
for (size_t i = 0; i < 10; i++)
{
StackPush(&st1, i);
}
N1::ST st2;
StackInit(&st2, 100);//知道100個
for (size_t i = 0; i < 100; i++)
{
StackPush(&st2, i);
}
//不知道可能會插入多少個
N1::ST st3;
StackInit(&st3);
return 0;
}
??二、函數(shù)重載
自然語言中,一個詞可以有多重含義,人們可以通過上下文來判斷該詞真實的含義,即該詞被重載了。
比如:以前有一個笑話,國有兩個體育項目大家根本不用看,也不用擔(dān)心。一個是乒乓球,一個
是男足。前者是“誰也贏不了!”,后者是“誰也贏不了!”
??1、函數(shù)重載概念
函數(shù)重載:是函數(shù)的一種特殊情況,C++允許在同一作用域中聲明幾個功能類似的同名函數(shù),這些同名函數(shù)的形參列表(參數(shù)個數(shù) 或 參數(shù)類型 或 參數(shù)類型順序)不同,常用來處理實現(xiàn)功能類似數(shù)據(jù)類型不同的問題。
重載函數(shù)之間是通過函數(shù)的 形參個數(shù) 或 形參類型 或 形參類型順序 來區(qū)分的(只有這三個區(qū)分標(biāo)準(zhǔn)),重載函數(shù)之間的區(qū)分在于形參的差異。
1??參數(shù)類型不同
// 1、參數(shù)類型不同
int Add(int left, int right)
{
cout << "int Add(int left, int right)" << endl;
return left + right;
}
double Add(double left, double right)
{
cout << "double Add(double left, double right)" << endl;
return left + right;
2??參數(shù)個數(shù)不同
// 2、參數(shù)個數(shù)不同
void func1()
{
cout << "func1()" << endl;
}
void func1(int a)
{
cout << "func1(int a)" << endl;
}
3??參數(shù)類型順序不同
// 3、參數(shù)類型順序不同
void func2(int a, char b)
{
cout << "func2(int a,char b)" << endl;
}
void func2(char b, int a)
{
cout << "func2(char b, int a)" << endl;
}
int main()
{
cout << Add(10, 20) << endl;
cout << Add(10.1, 20.2) << endl;
cout << endl;
func1();
func1(10);
cout << endl;
func2(10, 'a');
func2('a', 10);
return 0;
}
??注意以下兩種情況不構(gòu)成函數(shù)重載:
namespace M1
{
void func(int x)
{};
}
namespace M2
{
void func(int x)
{};
}
不在同一作用域中(函數(shù)重載必須在同一作用域中)??
namespace M1
{
void func(int x)
{};
}
namespace M1
{
void func(int x)
{};
}
自動合并了??
namespace M1
{
void func(int x)
{};
}
namespace M1
{
void func(double x)
{};
}
構(gòu)成函數(shù)重載?
函數(shù)重載和缺省參數(shù)沒有關(guān)系:
void func(int a)
{
cout << "void func(int a)" << endl;
}
void func(int a, int b = 1)
{
cout << "void func(int a, int b)" << endl;
}
int main()
{
func(1, 2);
//調(diào)用存在歧義,不知道調(diào)用哪個
//func(1);
return 0;
}
??三、C++支持函數(shù)重載的底層原理–函數(shù)名修飾
形成可執(zhí)行文件要四個階段:預(yù)處??編譯??匯編??鏈接
void func(int i, double d)
{
cout << "void func(int i, double d)" << endl;
}
void func(double d, int i)
{
cout << "void func(double d, int i)" << endl;
}
int main()
{
func(1, 1.1); // call func()
func(1.1, 1); // call func()
return 0;
}
對這段代碼編譯生成反匯編:
call指令是通過函數(shù)的符號表來定位函數(shù)的地址的
但是在C語言中,函數(shù)符號表中函數(shù)的命名規(guī)則就是原模原樣地照搬源文件中的函數(shù)標(biāo)識名。
C++符號表中的函數(shù)名修飾:
在符號表中,各個函數(shù)的命名都遵循一定的函數(shù)名修飾規(guī)則:
在g++編譯環(huán)境(支持C++的編譯器)中,符號表中的函數(shù)名經(jīng)過修飾后變成【_Z+函數(shù)名長度+函數(shù)名+類型首字母】(這點和C語言的符號表中函數(shù)的命名規(guī)則完全不同)
C++(g++編譯環(huán)境)這種名字修飾規(guī)則使得標(biāo)識名相同,形參不同的函數(shù)在符號表中得到了區(qū)分,因此編譯器在編譯和鏈接的過程中就能根據(jù)函數(shù)調(diào)用語句具體的實參類型明確地找到相應(yīng)重載函數(shù)的函數(shù)體的地址并訪問函數(shù)體中的指令,實現(xiàn)了重載函數(shù)的調(diào)用。
C語言中不存在這種名詞修飾規(guī)則,因此在符號表中標(biāo)識名相同的函數(shù)的符號表命名也是相同的,所以編譯器在編譯和鏈接的過程中無法對同標(biāo)識名函數(shù)進行區(qū)分,所以無法實現(xiàn)函數(shù)重載。
??這期內(nèi)容有一點點難理解,希望烙鐵們能理解消化,有所收獲哦!文章來源:http://www.zghlxwxcb.cn/news/detail-607454.html
總結(jié)??
以上就是 【C++】缺省參數(shù)&函數(shù)重載 的全部內(nèi)容啦????????
本文章所在【C++初階】專欄,感興趣的烙鐵可以訂閱本專欄哦??????
前途很遠,也很暗,但是不要怕,不怕的人面前才有路。??????
小的會繼續(xù)學(xué)習(xí),繼續(xù)努力帶來更好的作品??????
創(chuàng)作寫文不易,還多請各位大佬uu們多多支持哦??????文章來源地址http://www.zghlxwxcb.cn/news/detail-607454.html
到了這里,關(guān)于【C++】入門 --- 缺省參數(shù)&函數(shù)重載的文章就介紹完了。如果您還想了解更多內(nèi)容,請在右上角搜索TOY模板網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章,希望大家以后多多支持TOY模板網(wǎng)!