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

            ivy-jie

            progress ...

            C++博客 首頁 新隨筆 聯系 聚合 管理
              9 Posts :: 41 Stories :: 6 Comments :: 0 Trackbacks
            1、靜態全局變量

            在全局變量前,加上關鍵字static,該變量就被定義成為一個靜態全局變量。我們先舉一個靜態全局變量的例子,如下:
            //Example 1#include <iostream.h>void fn();static int n; //定義靜態全局變量void main(){ n=20; cout<<n<<endl; fn();}void fn(){ n++; cout<<n<<endl;}

            靜態全局變量有以下特點:
            該變量在全局數據區分配內存;
            未經初始化的靜態全局變量會被程序自動初始化為0(自動變量的值是隨機的,除非它被顯式初始化);
            靜態全局變量在聲明它的整個文件都是可見的,而在文件之外是不可見的;
            靜態變量都在全局數據區分配內存,包括后面將要提到的靜態局部變量。對于一個完整的程序,在內存中的

            分布情況如下圖:
            代碼區
            全局數據區
            堆區
            棧區


            一般程序的由new產生的動態數據存放在堆區,函數內部的自動變量存放在棧區。自動變量一般會隨著函數的退出而釋放空間,靜態數據(即使是函數內部的靜 態局部變量)也存放在全局數據區。全局數據區的數據并不會因為函數的退出而釋放空間。細心的讀者可能會發現,Example 1中的代碼中將

            static int n; //定義靜態全局變量
            改為
            int n; //定義全局變量
            程序照樣正常運行。
            的確,定義全局變量就可以實現變量在文件中的共享,但定義靜態全局變量還有以下好處:
            靜態全局變量不能被其它文件所用;
            其它文件中可以定義相同名字的變量,不會發生沖突;

            您可以將上述示例代碼改為如下:

            //Example 2//File1#include <iostream.h>void fn();static int n; //定義靜態全局變量void main(){ n=20; cout<<n<<endl; fn();}//File2#include <iostream.h>extern int n;void fn(){ n++; cout<<n<<endl;}
            編譯并運行Example 2,您就會發現上述代碼可以分別通過編譯,但運行時出現錯誤。 試著將
            static int n; //定義靜態全局變量
            改為
            int n; //定義全局變量
            再次編譯運行程序,細心體會全局變量和靜態全局變量的區別。
            2、靜態局部變量

            在局部變量前,加上關鍵字static,該變量就被定義成為一個靜態局部變量。

            我們先舉一個靜態局部變量的例子,如下:

            //Example 3#include <iostream.h>void fn();void main(){ fn(); fn(); fn();}void fn(){ static n=10; cout<<n<<endl; n++;}
            通常,在函數體內定義了一個變量,每當程序運行到該語句時都會給該局部變量分配棧內存。但隨著程序退出函數體,系統就會收回棧內存,局部變量也相應失效。
            但有時候我們需要在兩次調用之間對變量的值進行保存。通常的想法是定義一個全局變量來實現。但這樣一來,變量已經不再屬于函數本身了,不再僅受函數的控制,給程序的維護帶來不便。
            靜態局部變量正好可以解決這個問題。靜態局部變量保存在全局數據區,而不是保存在棧中,每次的值保持到下一次調用,直到下次賦新值。
            靜態局部變量有以下特點:

            該變量在全局數據區分配內存;
            靜態局部變量在程序執行到該對象的聲明處時被首次初始化,即以后的函數調用不再進行初始化;
            靜態局部變量一般在聲明處初始化,如果沒有顯式初始化,會被程序自動初始化為0;
            它始終駐留在全局數據區,直到程序運行結束。但其作用域為局部作用域,當定義它的函數或語句塊結束時,其作用域隨之結束;
            3、靜態函數

            在函數的返回類型前加上static關鍵字,函數即被定義為靜態函數。靜態函數與普通函數不同,它只能在聲明它的文件當中可見,不能被其它文件使用。

            靜態函數的例子:

            //Example 4#include <iostream.h>static void fn();//聲明靜態函數void main(){ fn();}void fn()//定義靜態函數{ int n=10; cout<<n<<endl;}
            定義靜態函數的好處:
            靜態函數不能被其它文件所用;
            其它文件中可以定義相同名字的函數,不會發生沖突;
            posted on 2009-05-24 10:47 ivy-jie 閱讀(203) 評論(0)  編輯 收藏 引用 所屬分類: c++
            国产亚洲精久久久久久无码| 亚洲日本va午夜中文字幕久久| 国产午夜久久影院| 久久99国产精品成人欧美| 亚洲人成无码网站久久99热国产| 久久久噜噜噜久久中文福利| 伊人久久大香线蕉精品| 久久天天躁狠狠躁夜夜avapp| 久久99毛片免费观看不卡| 性做久久久久久久久浪潮| 99久久婷婷免费国产综合精品| 午夜视频久久久久一区 | 久久这里只有精品首页| 日韩精品久久久久久久电影蜜臀 | 久久久久婷婷| 久久久久久久亚洲Av无码| 少妇久久久久久被弄到高潮 | 91精品国产乱码久久久久久| 久久午夜综合久久| 亚洲国产精品久久66| 无码人妻精品一区二区三区久久久 | 亚洲另类欧美综合久久图片区| 99久久人妻无码精品系列| 精品久久久无码21p发布| 欧洲性大片xxxxx久久久| 久久av免费天堂小草播放| 国产精品久久精品| 69SEX久久精品国产麻豆| 久久久久亚洲AV无码永不| 香蕉久久夜色精品升级完成| 久久夜色撩人精品国产小说| 久久不见久久见免费影院www日本| 国产成人久久精品一区二区三区| 亚洲第一极品精品无码久久| 久久久国产99久久国产一| 综合久久一区二区三区| 亚洲综合久久夜AV | 亚洲日韩中文无码久久| 国产亚洲色婷婷久久99精品| 国产精品视频久久久| 国产精品熟女福利久久AV|