參考資料:《21天學(xué)通C++》
函數(shù)重載
函數(shù)重載是指同一個函數(shù)名可以對應(yīng)著多個函數(shù)的實現(xiàn)淮韭,每一類實現(xiàn)對應(yīng)著一個函數(shù)體,這些函數(shù)的名字相同贴届,但是函數(shù)的參數(shù)類型不同靠粪。
例如,給同一個名為sum()的函數(shù)定義兩個不同的函數(shù)體毫蚓,該函數(shù)的功能是求兩個操作數(shù)的和占键。其中,一個函數(shù)實現(xiàn)求兩個整數(shù)的和元潘,另一個函數(shù)求兩個浮點數(shù)的和畔乙,這兩種功能都可以通過調(diào)用同一個名為sum()的函數(shù)來實現(xiàn)。
函數(shù)的重載
函數(shù)重載又稱函數(shù)的多態(tài)性翩概,是指同一個函數(shù)對應(yīng)著多個不同的函數(shù)牲距。
所謂“不同”,指的是這些函數(shù)的形參表必須互不相同钥庇,或者是形參個數(shù)不同嗅虏,或者是形參類型不同,或者是兩者都不同上沐。
例如皮服,以下是一些合法的重載函數(shù):
int func1(int, int);
int func1(int);
double func1(int, long);
double func1(long);
注意:重載函數(shù)的類型,也就是函數(shù)返回值的類型可以相同也可以不同参咙,但如果僅僅是返回類型不同而函數(shù)名龄广、形參表都相同,則是不合法的蕴侧,會被認為是同一個函數(shù)的多次聲明择同。
參數(shù)類型不同的函數(shù)重載
例1 參數(shù)類型不同的函數(shù)重載
#include <iostream>
using namespace std;
int add(int, int); //聲明計算整型數(shù)值的函數(shù)add
double add(double, double); //聲明計算浮點型數(shù)值的函數(shù)add
void main() {
cout << add(1, 2) << endl;
cout << add(1.2, 2.2) << endl;
}
int add(int x, int y) { //定義計算整型數(shù)值的函數(shù)add
return x + y;
}
double add(double a, double b) { //定義計算浮點型數(shù)值的函數(shù)add
return a + b;
}
輸出:
3
3.4
參數(shù)個數(shù)不同的重載函數(shù)
例2 參數(shù)個數(shù)不同的重載函數(shù)
#include <iostream>
using namespace std;
int min(int a, int b); //聲明帶有兩個參數(shù)的函數(shù)min
int min(int a, int b, int c); //聲明帶有三個參數(shù)的函數(shù)min
void main(){
cout << min(2, 3) << endl;
cout << min(3, 4, 5) << endl;
}
int min(int a, int b){
if(a <= b)
return a;
else
return b;
}
int min(int a, int b, int c){
int t = min(a, b);
int x = min(t, c);
return x;
}
輸出:
2
3
內(nèi)聯(lián)函數(shù)
內(nèi)聯(lián)函數(shù)也稱為內(nèi)嵌函數(shù),當在一個函數(shù)的定義或聲明前加上關(guān)鍵字inline則就把函數(shù)定義為內(nèi)聯(lián)函數(shù)净宵。
把一個函數(shù)定義為內(nèi)聯(lián)函數(shù)后敲才,在程序編譯階段裹纳,編譯器就會在每次調(diào)用該函數(shù)的地方都直接替換為該函數(shù)中的代碼,由此省去函數(shù)的調(diào)用等時間紧武,從而加快程序執(zhí)行速度剃氧。
例3 內(nèi)聯(lián)函數(shù)的應(yīng)用
#include <iostream>
using namespace std;
inline int abs(int x){
if(x < 0)
return -x;
else
return x;
}
void main(){
int a, b = 3, c, d = -4;
a = abs(b);
c = abs(d);
cout << "a = " << a << ", c = " << c << endl;
}
輸出:
a = 3, c = 4
條件編譯
條件編譯可以按不同的條件去編譯不同的程序部分,因而產(chǎn)生不同的代碼文件阻星。
C++的條件編譯有三種形式:
#ifdef形式
#ifdef形式是指該形式的第一個編譯命令為#ifdef朋鞍,這種形式的結(jié)構(gòu)如下:
#ifdef 標識符
程序段1
#else
程序段2
#endif
該形式的條件編譯的功能是:
如果標識符已經(jīng)被#define命令定義過,對程序段1進行編譯妥箕,否則對程序段進行編譯滥酥。
程序段2也可以沒有,則需要改成以下形式:
#ifdef 標識符
程序段
#endif
例4 #ifdef預(yù)編譯命令的應(yīng)用
#include <iostream>
#define PI 3.1415926 //定義宏P(guān)I
using namespace std;
void main(){
double radius, sr, a, ss;
#ifdef PI
{ //使用預(yù)編譯命令#ifdef
cout << "Please input radius:" << endl;
cin >> radius;
sr = PI * radius * radius;
cout << "The circle area is:" << "\t" << sr << endl;
}
#else
{
cout << "Please input a:" << endl;
cin >> a;
ss = a * a;
cout << "The square area is:" << "\t" << ss << endl;
}
#endif
}
輸入輸出:
Please input radius:
8
The circle area is: 201.062
注意:如果#define語句被注釋掉畦幢,那么系統(tǒng)將編譯第二個程序語句坎吻,計算正方形的面積,而不是計算圓的面積宇葱。
#ifndef形式
#ifndef形式是指該形式的第一個編譯命令為#ifndef瘦真,這種形式的結(jié)構(gòu)如下:
#ifndef 標識符
程序段1
#else
程序段2
#endif
#ifndef形式與第一種形式的功能正好相反。
#if形式
#if形式是指該形式的第一個編譯命令為#if贝搁,結(jié)構(gòu)如下:
#if 常量表達式
程序段1
#else
程序段2
#endif
這種形式的條件編譯結(jié)構(gòu)的功能是,如果常量表達式的值為真(非0)芽偏,則對程序段1進行編譯雷逆,否則對程序段2進行編譯。因此污尉,#if形式可以使程序在不同條件下膀哲,完成不同的功能。
例5 #if預(yù)編譯命令的應(yīng)用
#define flag 1
#include <iostream>
using namespace std;
int main(void) {
#if flag
{
double radius, sr;
cout << "Please input radius:" << endl;
cin >> radius;
sr = 3.1415926 * radius * radius;
cout << "The circle area is:" << "\t" << sr << endl;
}
#else
{
double a, ss;
cout << "Please input a:" << endl;
cin >> a;
cout << "The square area is:" << "\t" << ss << endl;
}
#endif
}
輸入輸出:
Please input radius:
2
The circle area is: 12.5664
注意:一般來說被碗,在程序中某宪,如果條件選擇包含的程序很長,采用條件編譯的方法是十分必要的锐朴。
其他命令
#error命令
#error命令用于程序的調(diào)試兴喂,在編譯中遇到#error會停止編譯,并顯示錯誤信息焚志。
其一般形式如下:
#error 出錯信息
注意:上述出錯信息不加引號衣迷。
#line命令
#line命令用于控制行號,一般在發(fā)布錯誤和警告信息時使用酱酬。
該命令的格式為:
#line number "filename"
此處的number是將會賦給下一行的新行數(shù)壶谒,其后面的行數(shù)從這一點逐個遞增。filename是可選參數(shù)膳沽,用來替換自此行以后出錯時顯示的文件名汗菜,直到有另外一個#line指令替換它或直到文件的末尾让禀。例如:
#line 1 "assigning variable"
int a?;
這段代碼會產(chǎn)生錯誤,顯示為“assigning variable”, line 1.