• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            focus on linux, c/c++, lua

            C++的函數(shù)返回引用

            從函數(shù)返回引用確保其引用的對象在函數(shù)執(zhí)行完后仍然存在。
            引用類型返回值的主要特征是可以作為左值,這意味著我們可以在賦值語句的左邊使用返回引用的函數(shù)的結(jié)果。
             
            永遠不要從函數(shù)中返回局部變量的引用
             
             
            C++中,返回引用是一個比較晦澀的概念。在書中,對此僅僅做了一個一般的介紹,并沒有展開。我覺得有必要對此進行一定的展開。
            (1)首先,返回引用,要求在函數(shù)的參數(shù)中,包含有以引用 方式或指針 方式存在的,需要被返回的參數(shù)。比如:
            int & abc(int a, int b, int c, int & result){
              result = a + b + c;
              return result;
            }
            這種形式也可改寫為:
            int & abc(int a, int b, int c, int *result){
              *result = a + b + c;
              return *result;
            }
            但是,如下的形式是不可以的:
            int & abc(int a, int b, int c){
              return  a + b + c;
            }
            (2)由于返回值直接指向了一個生命期尚未結(jié)束的變量,因此,對于函數(shù)返回值(或者稱為函數(shù)結(jié)果)本身的任何操作,都在實際上,是對那個變量的操作,這就是引入const 類型的返回的意義。
            當使用了const 關(guān)鍵字后,即意味著函數(shù)的返回值不能立即得到修改!如下代碼,將無法編譯通過,這就是因為返回值立即進行了++操作(相當于對變量z進行了++操作),而這對于該函數(shù)而言,是不允許的。如果去掉const,再行編譯,則可以獲得通過,并且打印形成z = 7 的結(jié)果。
            include <iostream>
            include <cstdlib>
            const int & abc(int a, int b, int c, int & result){
              result = a + b + c;
              return result;
            }
            int main() {
              int a = 1; int b = 2; int c=3;
              int z;
              abc(a, b, c)++;
              cout << "z= " << z << endl;
              SYSTEM("PAUSE" );
              return 0;
            }

            標簽:
             
            眾所周知,C++函數(shù)可以傳入引用參數(shù)和返回引用。

            函數(shù)引用參數(shù)避免了過多的指針操作,對加強函數(shù)的可讀性很有幫助;另外,在傳入體積很大的類型的變量時,引用參數(shù)可以避免拷貝對象,加快程序運行效率。
            函數(shù)支持引用型的返回值是為什么呢?這個問題要一分為二:對于類類型的引用返回值,函數(shù)可以在使用重載運算符的串聯(lián)表達式中使用,而不用擔心構(gòu)造多個對象。
              
            #include <stdio.h>
            #include <iostream>
            using namespace std;

            class Rec
            {
            public:
                    int a;
                    int b;
                    friend ostream & operator<<(ostream &os,Rec& b)
                    {
                            os<<"["<<b.a<<"]";
                            return os;
                    }
            };

            Rec & funRec(Rec& obj)
            {
                    return obj;
            }

            int main(int argc , char* args[])
            {
                    Rec obj;
                    Rec *ptr = &(funRec(obj));
                    Rec ano = funRec(obj);

                    printf("&obj = %p\nptr = %p\n&ano = %p\n", &obj, ptr, &ano);

                    return 0;
            } 運行結(jié)果:
            [cinson@localhost test]$ ./a.out     
            &obj = 0xbf90e338
            ptr = 0xbf90e338
            &ano = 0xbf90e330
            可見,紅色代碼只會生成一個對象,綠色代碼部分需要調(diào)用拷貝構(gòu)造函數(shù)。因為fucRec傳入引用參數(shù),返回引用對象。如果返回的不是引用對象,那么在 語句Rec *ptr = &( funRec(obj) ); 編譯不過 。


            但是,對于返回基本類型如int型的函數(shù),返回引用類型就變得非常迷惑了。
            有代碼:
            int &func( int & a)
            {
               return a;
            }

            int main( int argc , char * args[])
            {
               
               int a=0;
               int b=func(a);
               printf( "&a=0X%08X,&b=%08X\n" ,&a,&b);

            } 運行結(jié)果:
               &a=0X0012FF7C,&b=0012FF78
            這里可以看到,返回變量的地址和傳入地址是不同的。變量b是main函數(shù)中自己的棧中生成的。
            這一點從匯編代碼片段中可以看得更清楚:
            ; Line 38
               lea   eax, DWORD PTR _a$[ebp]
               push   eax
               call   ?func@@YAAAHAAH@Z       ; func
               add   esp, 4
               mov   ecx, DWORD PTR [eax]
               mov   DWORD PTR _b$[ebp], ecx   
             
            int& c=func(a)
            那么c就是指向a,
            a變化那么c也跟著變化,
             
            在上面b的情況,
            是重新分配了一個空間,
            因此不會同步變化.


            絕不要返回一個局部棧對象的指針或引用,(編譯不過)
            絕不要返回一個被分配的堆對象的引用,(new了內(nèi)存之后,不知道在什么時候delete)
            如果存在需要一個以上這樣的對象的可能性時,絕不要返回一個局部 static 對象的指針或引用。(多個對象操作同一個static對象,不合適吧)

            posted on 2011-02-21 15:09 zuhd 閱讀(711) 評論(0)  編輯 收藏 引用 所屬分類: c/c++

            无码乱码观看精品久久| 色成年激情久久综合| 久久精品国产亚洲5555| 午夜精品久久久久久影视777| 日韩精品久久久久久久电影| 狠狠色狠狠色综合久久| 亚洲精品乱码久久久久久蜜桃图片| 久久er99热精品一区二区| 久久精品嫩草影院| 亚洲国产小视频精品久久久三级 | 久久久无码精品亚洲日韩蜜臀浪潮| 久久99精品久久久久久久不卡 | 久久天天躁狠狠躁夜夜avapp| 狠狠色婷婷久久综合频道日韩| 久久99精品国产| 免费无码国产欧美久久18| 国产亚洲欧美精品久久久| 亚洲欧洲精品成人久久曰影片| 久久综合国产乱子伦精品免费| 国产精品成人久久久久久久| 日日躁夜夜躁狠狠久久AV| 色综合久久中文字幕综合网| 国产精品久久久久久久久| 久久精品国产日本波多野结衣| 青青草国产成人久久91网| 国产69精品久久久久久人妻精品| 精品久久久久久国产牛牛app| 成人免费网站久久久| 亚洲人成精品久久久久| 久久久精品久久久久影院| 久久久久国产精品麻豆AR影院| 热久久国产精品| 久久综合狠狠色综合伊人| 人妻无码久久一区二区三区免费| 热久久最新网站获取| 亚洲精品无码久久久久AV麻豆| 久久人人爽人人爽人人片AV麻豆| 精品多毛少妇人妻AV免费久久| 久久中文字幕一区二区| 国产99精品久久| a级毛片无码兔费真人久久|