首頁 > 軟體

C++深入分析講解函數與過載知識點

2022-06-02 14:05:43

函數的預設(預設)引數

1、預設引數的定義

c++在宣告函數原型的時可為一個或者多個引數指定預設(預設)的引數值,當函數呼叫的時候如果沒有傳遞該引數值,編譯器會自動用預設值代替。

//函數的預設引數 指定x的預設值為10 y為20
int my_add(int x=10,int y=20)
{
    return x+y;
}
void test02()
{
    //如果函數傳參 那麼各自的預設引數將無效
    cout<<"my_add = "<<my_add(100,200)<<endl;//300
    //如果某個引數未被傳參 將啟用預設值x=100 y使用預設值20
    cout<<"my_add = "<<my_add(100)<<endl;//120
    //x=10  y=20
    cout<<"my_add = "<<my_add()<<endl;//30
}

2、預設引數的注意點

(1)、函數的預設引數從左向右,如果一個引數設定了預設引數,那麼這個引數之後的引數都必須設定預設引數

//函數的預設引數從左向右
int func01(int x,int y=20,int z=30)
{
    return x+y+z;
}
void test03()
{
    cout<<func01(100,200)<<endl;//330
    cout<<func01(100)<<endl;//150
    //cout<<func01()<<endl;//err x沒有設定預設引數 必須傳參
}
int fun(int a, int b, int c=10);//正確
int fun(int a, int b=20, int c=10);//正確
int fun(int a=30, int b=20, int c=10);//正確
int fun(int a, int b=20, int c);//不正確

(2)、如果函數宣告和函數定義分開寫,函數宣告和函數定義不能同時設定預設引數

(3)、預設引數一般在函數宣告的時候 設定

fun.cpp

int func02(int x,int y,int z)
{
    return x+y+z;
}

main.cpp

//分檔案 函數定義處的預設引數 是無效的
//建議:分檔案是 在宣告 給預設引數
extern int func02(int x,int y=25,int z=35);
//extern int func02(int x,int y,int z);//err
void test04()
{
    cout<<func02(100,200)<<endl;//335
    cout<<func02(100)<<endl;//160
}

佔位引數

c++在宣告函數時,可以設定佔位引數。

佔位引數只有引數型別宣告,而沒有引數名宣告。

如果函數的引數只有型別名 沒有形參名,這個引數就是佔位引數

注意:

由於有型別名 所以 函數呼叫的時候 必須給佔位引數傳參。

由於沒有形參名 所以 函數內部 是無法使用佔位引數。

1、佔位引數 函數內部無法使用

void func03(int x,int y,int)
{
    cout<<"x = "<<x<<", y = "<<y<<endl;
    return;
}
void test05()
{
    //func03(10,30,"hehe");//err "hehe"和int型別不符
    func03(10,30,40);
}

2、佔位引數 可以設定成預設引數

void TestFunc01(int a,int b,int=100)
{ 
    //函數內部無法使用佔位引數 cout << "a + b = " << a + b << endl; 
}
TestFunc01(10, 20,30);//ok
TestFunc01(10, 20);//ok

什麼時候用,在後面我們要講的操作符過載的後置++要用到這個

函數過載

函數過載體現了 c++ 的多型的特性

函數過載:同一個函數名在不同場景下可以具有不同的含義。

函數過載意義:方便的使用函數名。

函數過載的條件: 同一個作用域 引數個數不同 引數型別不同 引數順序不同(重要)

void myFunc(int a)
{
    cout<<"int的myFunc"<<endl;
}
void myFunc(int a,int b)
{
    cout<<"int,int 的myFunc"<<endl;
}
void myFunc(int a,double b)
{
    cout<<"int , double的myFunc"<<endl;
}
void myFunc(double a,int b)
{
    cout<<"double,int的myFunc"<<endl;
}
void test06()
{
    myFunc(10);//int
    myFunc(10,20);//int int
    myFunc(10,20.2);//int double
    myFunc(10.1,20);//double int
}

注意:

1、函數的返回值型別 不能作為 函數過載的依據。

2、函數過載和預設引數一起使用,需要額外注意二義性問題的產生

void myFunc02(int a)
{
    cout<<"int的myFunc02"<<endl;
}
void myFunc02(int a,int b=10)//預設引數
{
    cout<<"int,int 的myFunc02"<<endl;
}
void test07()
{
    //myFunc02(int a) 和 myFunc02(int a,int b=10)都能識別
    myFunc02(10);//二義性產生
}

3、函數過載的原理(瞭解)

到此這篇關於C++深入分析講解函數與過載知識點的文章就介紹到這了,更多相關C++函數與過載內容請搜尋it145.com以前的文章或繼續瀏覽下面的相關文章希望大家以後多多支援it145.com!


IT145.com E-mail:sddin#qq.com