亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

C++中函數(shù)的用法小結(jié)

 更新時間:2014年02月25日 14:36:37   作者:  
這篇文章主要為大家分享下本人在閱讀《C++ Primer》函數(shù)一章時的讀書總結(jié),需要的朋友可以參考下

函數(shù)在C++中的使用,無非2種地方,一處是函數(shù)的定義,一處是函數(shù)的調(diào)用。而函數(shù)的定義則非常簡單,由三個部分組成:函數(shù)的返回類型、函數(shù)名和函數(shù)的形參表。當(dāng)然,這里不同的函數(shù)定義可以還會稍有不同,比如類的成員函數(shù)、內(nèi)聯(lián)函數(shù)等。這里我們主要討論函數(shù)的調(diào)用時需要注意的一些問題。

一、參數(shù)傳遞

我們將函數(shù)定義或聲明里的參數(shù)叫形參,而在調(diào)用函數(shù)時傳入的參數(shù)叫實參。那么根據(jù)形參類型的不同,有幾下形式的參數(shù)傳遞。

1,非引用形參

1)普通的內(nèi)置類型

普通非引用類型的參數(shù)通過復(fù)制對應(yīng)的實參實現(xiàn)形參的初始化。當(dāng)用實參的副本初始化形參時,函數(shù)并沒有訪問調(diào)用所傳遞的實參的本身,因此函數(shù)不可能改實參的值。比如下面的交換兩個數(shù)的程序:

復(fù)制代碼 代碼如下:

void swap(int v1, int v2)
{
    int temp = v1;
    v2 = v1;
    v1 = temp;
}

swap(a, b);// 調(diào)用swap

上面程序中,實參為a與b,但是在調(diào)用時,v1與v2接受的是a與b的副本,所以實際上a與b的值沒有變化。

2)指針形參

函數(shù)的形參可以是指針,此時將復(fù)制實參指針,其實這類跟1)原理類似,函數(shù)內(nèi)并無法改變實參的指針值。只是函數(shù)可以通過復(fù)制到的地址改變實參指針?biāo)赶虻闹怠?/P>

復(fù)制代碼 代碼如下:

void swap(int* v1, int* v2)
{
    int temp = *v2;
    *v2 = *v1;
    *v1 = temp;
}
int main()
{
    int a = 10,b = 20;
    int *p1 = &a,*p2 = &b;
    swap(p1,p2);
    return 0;
}

上面程序中定義的swap的形參為指針類型,main中調(diào)用swap,實際上swap并不能改變p1與p2的值,只是改變了它們所指向的值。

3)const 形參

對于普通的非引用類型用const修飾實際上是沒有意義的,因為本來函數(shù)就不會改變實參的值。像下面的定義,實際中編譯器會忽略const的定義,而將其視為int型。

復(fù)制代碼 代碼如下:

void fcn(const int i);

2,引用形參

1)在上面的程序中我們看到,如果想交換兩個變量的值,通過調(diào)用普通的非引用類型形參的函數(shù),并不能實現(xiàn)。用它們的指針可以,同時我們也可以用引用。

復(fù)制代碼 代碼如下:

void swap(int& v1, int& v2)
{
    int temp = v2;
    v2 = v1;
    v1 = temp;
}
int main()
{
    int a = 10,b = 20;
    swap(a,b);
    return 0;
}

在實際調(diào)用swap時,v1與v2實際相當(dāng)于a與b的另一個名字。

2)在有的時候我們需要向函數(shù)傳遞大型對象,需要使用引用形參,如果直接使用復(fù)制實參的形式可以,但是它的效率太低了,甚至有些對象是無法復(fù)制的。但是使用引用形參時,我們不希望函數(shù)改變了實參傳入的值,我們就可以使用const來限定形參。下面程序用來判斷哪個字符串更長,明顯我們不希望函數(shù)會改變字符串的內(nèi)容,我們就可以用const引用型的形參。

復(fù)制代碼 代碼如下:

bool isLonger(const string &s1, const string &s2)
{
    return s1.size() > s2.size();
}

所以,如果使用引用形參的惟一的目的是避免復(fù)制實參時,則應(yīng)將形參定義為const引用。

3)在使用引用形參函數(shù)時,有兩點值得注意:

不要用const限定的實參或字面值來調(diào)用非const引用形參函數(shù)。因為這樣函數(shù)內(nèi),可以改變實參的值,這不合法。

非const引用形參只能與完全同類型的非const對象關(guān)聯(lián)。

4)傳遞指向指針的引用

如下有下面的程序:

復(fù)制代碼 代碼如下:

void swap(int* &v1, int* &v2)
{
    int* temp = v2;
    v2 = v1;
    v1 = temp;
}
int main()
{
    int a = 10,b = 20;
    int* p1 = &a, *p2 = &b;
    swap(p1,p2);
    return 0;
}

上面的程序依然不能改變a與b的值,但是它改變了p1與p2的值,現(xiàn)在p1指向了b,而p2指向了a。

3,其他類型的形參

1)vector和其他類型的形參:一般在這種類型作為形參時,為了避免復(fù)制應(yīng)該考慮形參聲明為引用類型。C++程序員傾向于傳遞容器中需要處理的元素的迭代器來傳遞容器。

2)數(shù)組形參:由于數(shù)組不能復(fù)制,所以不能直接編寫數(shù)組類型的形參函數(shù),一般通過傳遞指向數(shù)組的元素的指針來處理數(shù)組。值得注意的是在通過引用傳遞數(shù)組時,在調(diào)用函數(shù)時形參與實參的類型要匹配。

復(fù)制代碼 代碼如下:

void printValues(int (&ar)[10]);
int main()
{
    int i = 0, j[2] = { 0, 1 };
    int k[10] = {0,1,2,3,4,5,6,7,8,9};
    printValues(i);  //error int不能初始化 int(&)[10]
    printValues(j);  //error int[2] 不能初始化 int(&)[10]
    printValues(k);   // ok
    return 0;
}

二、函數(shù)的返回值

1)沒有返回值

很多函數(shù)并沒有返回值,尤其是現(xiàn)在C++風(fēng)格,習(xí)慣于把需要的結(jié)果作為引用形參。這類型函數(shù)一般沒有return語句,有時候有return是使函數(shù)中途中斷執(zhí)行。

2)返回非引用類型

這種情況在函數(shù)調(diào)用處,程序會用一個臨時變量復(fù)制函數(shù)的返回值。

3)返回引用

當(dāng)函數(shù)返回引用類型時,并沒有復(fù)制返回值。相反,返回的是對象本身。

在返回引用這種情況下,注意不要返回局部變量的引用,因為局部變量在函數(shù)體內(nèi)定義,當(dāng)函數(shù)執(zhí)行完后就銷毀了,所謂的引用也就沒有意義了。同理,不要返回指向局部變量的指針。

三、重載函數(shù)

出現(xiàn)在相同作用域中的兩個函數(shù),如果具有相同的名字而形參不同,則稱為重載函數(shù)。

1)注意區(qū)分函數(shù)重載與重復(fù)聲明

有些看起來不同的形參,本質(zhì)是相同的。下面代碼中的都是重復(fù)聲明的例子

復(fù)制代碼 代碼如下:

typedef double newDouble;
int func(double i);
int func(newDouble i);  // 沒有新類型

int func1(int, int = 1); //只是提供默認參數(shù)
int func1(int ,int);

int func2(int);
int func2(const int);  //對于普通非引用形參用cosnt修飾是沒有意義的

2)重載與作用域

局部聲明的函數(shù),將屏蔽所有全局作用的同名函數(shù)。下面例子顯示,即使全局作用的函數(shù)更加匹配調(diào)用的實參類型,但是仍然調(diào)用的是局部的函數(shù)。

復(fù)制代碼 代碼如下:

void print(int);
int main()
{
    void print(double);
    print(42);
    return 0;
}

上面程序中,將調(diào)用void print(double)函數(shù),雖然42是int型。

3)重載確定的三個步驟

如果定義了眾多的函數(shù)重載,將存在函數(shù)調(diào)用到底與哪個重載函數(shù)相匹配的問題。我們通過下面的示例代碼來說明問題:

復(fù)制代碼 代碼如下:

void f();  // 1
void f(int);// 2
void f(double);// 3
void f(int, int);// 4
void f(double, double);// 5

第一步:確定候選函數(shù)

假如我們調(diào)用f(4.2),那么先找到同名函數(shù),并且在作用域內(nèi)可見,上面例子中5個函數(shù)都滿足。

第二步:選擇可行的函數(shù)

必須滿足2個條件:一是函數(shù)形參與該調(diào)用實參個數(shù)相同;第二,每個實參的類型必須與對應(yīng)的類型匹配,或者可以被隱式轉(zhuǎn)換為對應(yīng)的形參類型。這里我們再調(diào)用f(4.2)時,排除了1、4、5號函數(shù),只剩下2與3。其中2號函數(shù)可以通過類型轉(zhuǎn)換來滿足。

第三步:尋找最佳匹配

在經(jīng)過第二步確定后,剩下2與3函數(shù),那么2需要進行類型轉(zhuǎn)換,顯然3是最佳匹配了。

但是如果這樣調(diào)用f(42,4.2)。這時候就會出現(xiàn)二義性,編譯器將提示。

還有一種要注意的就是有默認參數(shù)的函數(shù),比如我們定義6號函數(shù)為void f(double,int =1);那么在調(diào)用f(4.2)時就會有二義性。

可基于函數(shù)的引用形參是指向const對象還是指向非const對象實現(xiàn)函數(shù)重載。

相關(guān)文章

  • C語言之飛機大戰(zhàn)游戲

    C語言之飛機大戰(zhàn)游戲

    這篇文章主要為大家詳細介紹了C語言之飛機大戰(zhàn),文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-12-12
  • C++實現(xiàn)車票管理系統(tǒng)

    C++實現(xiàn)車票管理系統(tǒng)

    這篇文章主要為大家詳細介紹了C++實現(xiàn)車票管理系統(tǒng),連接數(shù)據(jù)庫MySQL,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-03-03
  • 一文學(xué)會數(shù)據(jù)結(jié)構(gòu)-堆

    一文學(xué)會數(shù)據(jù)結(jié)構(gòu)-堆

    本文主要介紹了數(shù)據(jù)結(jié)構(gòu)-堆,文中通過圖片和大量的代碼講解的非常詳細,需要學(xué)習(xí)的朋友可以參考下這篇文章,希望可以幫助到你
    2021-08-08
  • C語言逆向分析語法超詳細分析

    C語言逆向分析語法超詳細分析

    這篇文章主要介紹了C語言逆向分析語法,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)吧
    2022-11-11
  • C語言棧的表示與實現(xiàn)實例詳解

    C語言棧的表示與實現(xiàn)實例詳解

    這篇文章主要介紹了C語言棧的表示與實現(xiàn),對于數(shù)據(jù)結(jié)構(gòu)與算法的研究有一定的借鑒價值,需要的朋友可以參考下
    2014-07-07
  • C++實現(xiàn)俄羅斯方塊源碼

    C++實現(xiàn)俄羅斯方塊源碼

    這篇文章主要為大家詳細介紹了C++實現(xiàn)俄羅斯方塊源碼完整版,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-06-06
  • C++實現(xiàn)AVL樹的基本操作指南

    C++實現(xiàn)AVL樹的基本操作指南

    AVL樹是高度平衡的而二叉樹,它的特點是AVL樹中任何節(jié)點的兩個子樹的高度最大差別為1,下面這篇文章主要給大家介紹了關(guān)于C++實現(xiàn)AVL樹的相關(guān)資料,需要的朋友可以參考下
    2022-01-01
  • C++模擬實現(xiàn)string的方法詳解

    C++模擬實現(xiàn)string的方法詳解

    標(biāo)準(zhǔn)庫類型string表示可變長的字符序列,使用string類型必須首先包含string的頭文件。本文將利用C++模擬實現(xiàn)string,需要的可以參考一下
    2022-11-11
  • C++泛型編程綜合講解

    C++泛型編程綜合講解

    泛型編程與面向?qū)ο缶幊痰哪繕?biāo)相同,即使重用代碼和抽象通用概念的技術(shù)更加簡單。但是面向?qū)ο缶幊虖娬{(diào)編程的數(shù)據(jù)方面,泛型編程強調(diào)的是獨立于特定數(shù)據(jù)類型
    2022-12-12
  • C++ TinyXML解析案例詳解

    C++ TinyXML解析案例詳解

    這篇文章主要介紹了C++ TinyXML解析案例詳解,本篇文章通過簡要的案例,講解了該項技術(shù)的了解與使用,以下就是詳細內(nèi)容,需要的朋友可以參考下
    2021-08-08

最新評論