• <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>

            程序讓生活更美好

            半畝方塘 天光云影

              C++博客 ::  :: 新隨筆 :: 聯(lián)系 ::  :: 管理 ::
              55 隨筆 :: 4 文章 :: 202 評論 :: 0 Trackbacks

            (1)auto

              這個這個關鍵字用于聲明變量的生存期為自動,即將不在任何類、結構、枚舉、聯(lián)合和函數(shù)中定義的變量視為全局變量,而在函數(shù)中定義的變量視為局部變量。這個關鍵字不怎么多寫,因為所有的變量默認就是auto的。

            (2)register

              這個關鍵字命令編譯器盡可能的將變量存在CPU內(nèi)部寄存器中而不是通過內(nèi)存尋址訪問以提高效率。

            (3)static

              常見的兩種用途:
                1>統(tǒng)計函數(shù)被調(diào)用的次數(shù);
                2>減少局部數(shù)組建立和賦值的開銷.變量的建立和賦值是需要一定的處理器開銷的,特別是數(shù)組等含有較多元素的存儲類型。在一些含有較多的變量并且被經(jīng)常調(diào)用的函數(shù)中,可以將一些數(shù)組聲明為static類型,以減少建立或者初始化這些變量的開銷.

              詳細說明:
                1>、變量會被放在程序的全局存儲區(qū)中,這樣可以在下一次調(diào)用的時候還可以保持原來的賦值。這一點是它與堆棧變量和堆變量的區(qū)別。
                2>、變量用static告知編譯器,自己僅僅在變量的作用范圍內(nèi)可見。這一點是它與全局變量的區(qū)別。
                3>當static用來修飾全局變量時,它就改變了全局變量的作用域,使其不能被別的程序extern,限制在了當前文件里,但是沒有改變其存放位置,還是在全局靜態(tài)儲存區(qū)。

              使用注意:
                1>若全局變量僅在單個C文件中訪問,則可以將這個變量修改為靜態(tài)全局變量,以降低模塊間的耦合度;
                2>若全局變量僅由單個函數(shù)訪問,則可以將這個變量改為該函數(shù)的靜態(tài)局部變量,以降低模塊間的耦合度;
                3>設計和使用訪問動態(tài)全局變量、靜態(tài)全局變量、靜態(tài)局部變量的函數(shù)時,需要考慮重入問題(只要輸入數(shù)據(jù)相同就應產(chǎn)生相同的輸出)。

            (4)const

              被const修飾的東西都受到強制保護,可以預防意外的變動,能提高程序的健壯性。它可以修飾函數(shù)的參數(shù)、返回值,甚至函數(shù)的定義體。

              作用:
                1>修飾輸入?yún)?shù)
                  a.對于非內(nèi)部數(shù)據(jù)類型的輸入?yún)?shù),應該將“值傳遞”的方式改為“const引用傳遞”,目的是提高效率。例如將void Func(A a) 改為void Func(const A &a)。
                  b.對于內(nèi)部數(shù)據(jù)類型的輸入?yún)?shù),不要將“值傳遞”的方式改為“const引用傳遞”。否則既達不到提高效率的目的,又降低了函數(shù)的可理解性。例如void Func(int x) 不應該改為void Func(const int &x)。
                2>用const修飾函數(shù)的返回值
                  a.如果給以“指針傳遞”方式的函數(shù)返回值加const修飾,那么函數(shù)返回值(即指針)的內(nèi)容不能被修改,該返回值只能被賦給加const修飾的同類型指針。
                   如對于: const char * GetString(void);
                   如下語句將出現(xiàn)編譯錯誤:
                    char *str = GetString();//cannot convert from 'const char *' to 'char *';
                   正確的用法是:
                   const char *str = GetString();
                  b.如果函數(shù)返回值采用“值傳遞方式”,由于函數(shù)會把返回值復制到外部臨時的存儲單元中,加const修飾沒有任何價值。 如不要把函數(shù)int GetInt(void) 寫成const int GetInt(void)。
                3>const成員函數(shù)的聲明中,const關鍵字只能放在函數(shù)聲明的尾部,表示該類成員不修改對象.

               說明:
                const type m; //修飾m為不可改變
               示例:
                typedef char * pStr; //新的類型pStr;
                char string[4] = "abc";
                const char *p1 = string;
                p1++; //正確,上邊修飾的是*p1,p1可變
                const pStr p2 = string;
                p2++; //錯誤,上邊修飾的是p2,p2不可變,*p2可變
               同理,const修飾指針時用此原則判斷就不會混淆了。
                const int *value; //*value不可變,value可變
                int* const value; //value不可變,*value可變
                const (int *) value; //(int *)是一種type,value不可變,*value可變
                          //邏輯上這樣理解,編譯不能通過,需要tydef int* NewType;
                const int* const value;//*value,value都不可變

            (5)volatile

              表明某個變量的值可能在外部被改變,優(yōu)化器在用到這個變量時必須每次都小心地重新讀取這個變量的值,而不是使用保存在寄存器里的備份。它可以適用于基礎類型如:int,char,long......也適用于C的結構和C++的類。當對結構或者類對象使用volatile修飾的時候,結構或者類的所有成員都會被視為volatile.
              該關鍵字在多線程環(huán)境下經(jīng)常使用,因為在編寫多線程的程序時,同一個變量可能被多個線程修改,而程序通過該變量同步各個線程。
              簡單示例:
               DWORD __stdcall threadFunc(LPVOID signal)
               {
                 int* intSignal=reinterpret_cast(signal);
                 *intSignal=2;
                 while(*intSignal!=1)
                 sleep(1000);
                 return 0;
               }
              該線程啟動時將intSignal 置為2,然后循環(huán)等待直到intSignal 為1 時退出。顯然intSignal的值必須在外部被改變,否則該線程不會退出。但是實際運行的時候該線程卻不會退出,即使在外部將它的值改為1,看一下對應的偽匯編代碼就明白了:
                 mov ax,signal
                 label:
                 if(ax!=1)
                 goto label
              對于C編譯器來說,它并不知道這個值會被其他線程修改。自然就把它cache在寄存器里面。C 編譯器是沒有線程概念的,這時候就需要用到volatile。volatile 的本意是指:這個值可能會在當前線程外部被改變。也就是說,我們要在threadFunc中的intSignal前面加上volatile關鍵字,這時候,編譯器知道該變量的值會在外部改變,因此每次訪問該變量時會重新讀取,所作的循環(huán)變?yōu)槿缦旅鎮(zhèn)未a所示:
                 label:
                 mov ax,signal
                 if(ax!=1)
                 goto label

              注意:一個參數(shù)既可以是const同時是volatile,是volatile因為它可能被意想不到地改變。它是const因為程序不應該試圖去修改它。

            (6)extern

              extern 意為“外來的”···它的作用在于告訴編譯器:有這個變量,它可能不存在當前的文件中,但它肯定要存在于工程中的某一個源文件中或者一個Dll的輸出中。

            posted on 2007-09-11 23:33 北風之神007 閱讀(2107) 評論(1)  編輯 收藏 引用 所屬分類: c/c++

            評論

            # re: 說明以下關鍵字的作用 auto static register const volatile extern 2008-11-07 13:49 cher.song
            很好啊,很多以前看了很多遍都不懂的東西。
            看完這個都懂了。
              回復  更多評論
              

            999久久久无码国产精品| 国产亚州精品女人久久久久久 | 久久99国产精品二区不卡| 国产香蕉久久精品综合网| 激情五月综合综合久久69| 爱做久久久久久| 久久青青草原国产精品免费 | 国产99精品久久| 久久精品国产第一区二区三区| 色88久久久久高潮综合影院| 亚洲国产精品无码久久SM| 无码国内精品久久人妻蜜桃 | 久久人人爽人人爽人人片AV东京热| 久久久无码精品午夜| 亚洲成av人片不卡无码久久| 亚洲欧美日韩精品久久亚洲区| 亚洲国产小视频精品久久久三级| 久久乐国产精品亚洲综合| 久久婷婷国产剧情内射白浆| 久久精品国产亚洲AV香蕉| 久久精品国产亚洲AV香蕉| 久久精品国产精品青草app| 久久国产美女免费观看精品| 久久久久九国产精品| 亚洲熟妇无码另类久久久| 久久香蕉一级毛片| 欧美国产精品久久高清| 国产偷久久久精品专区| 国产麻豆精品久久一二三| 久久久久亚洲AV无码专区网站 | 99精品国产在热久久无毒不卡 | 免费观看久久精彩视频| 久久精品国产一区二区三区| 亚洲色婷婷综合久久| 国产成人久久777777| 中文字幕日本人妻久久久免费| 久久久青草久久久青草| 无码伊人66久久大杳蕉网站谷歌| 国产亚洲欧美成人久久片| 久久婷婷色综合一区二区| 国产精品女同一区二区久久|