• <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>
            SmartPtr
            本博客已搬至:http://www.cnblogs.com/baiyanhuang/
            posts - 29,comments - 176,trackbacks - 0
            By SmartPtr(http://m.shnenglu.com/SmartPtr/) 
             
             今天收到學(xué)弟的一封信,問我關(guān)于變量與內(nèi)存的一些問題,其實(shí)這是一個(gè)很基本的概念,但可能還有很多人對這個(gè)還不太了解(包括自己可能也會(huì)有誤解的地方),遂將原信與回信放于此:
              
            原信
            問幾個(gè)我比較混亂的問題。
            看一下我寫的對不對
            int g_variable; //占編譯后的代碼空間,運(yùn)行時(shí)占內(nèi)存(常住內(nèi)存)
            const int c_value = 5;    //占編譯后的代碼空間, 是不是常住內(nèi)存呢?
            void fun(void)
            {
            static int s_variable;    //占編譯后的代碼空間,運(yùn)行時(shí)占內(nèi)存(常住內(nèi)存)
            int variable;    //fun 被調(diào)用時(shí)放入棧中(占用內(nèi)存)
            }
            如果我定義一下大一點(diǎn)的數(shù)組,如:
            const int c_array[100] = ...;
            程序一運(yùn)行時(shí)就會(huì)被分配 400 Byte 的內(nèi)存空間嗎?還是在我使用它時(shí)會(huì)被分配400 Byte 的內(nèi)存空間嗎?

            回信
            先給你大概講一下基本概念, 問題在原信下用紅色回答
             
            一個(gè)程序的運(yùn)行起來后,其在內(nèi)存中有5個(gè)區(qū)域
            1. 程序代碼區(qū)
            這個(gè)很簡單,存放執(zhí)行指令,代碼要執(zhí)行,肯定要加載進(jìn)內(nèi)存, 我們不必關(guān)心。
             
            2. 文字常量區(qū)
            一般我們這樣定義一個(gè)字符串時(shí),其是在文字常量區(qū)的:
            char* s1 = "hello, world";
            char* s2 = "hello, world";
            if(s1 == s2)
              printf("s1和s2指向同一個(gè)在文字常量區(qū)的字符串");
             
            這里, s1和s2指向的是同一個(gè)字符串
             
            3. 靜態(tài)存儲(chǔ)區(qū)
            全局變量,靜態(tài)變量會(huì)放在這個(gè)區(qū)域,事實(shí)上,全局變量也是靜態(tài)的。
             
            以上1,2,3三個(gè)區(qū)域的內(nèi)存在程序起來的時(shí)候就開辟好了的。
             
            4. 棧
            局部變量就是在棧里的。另外,函數(shù)調(diào)用時(shí)的參數(shù)也是在棧里的,這個(gè)現(xiàn)在不必關(guān)心
             
            5. 堆
            malloc或new出來的內(nèi)存就是在堆里的,需要程序員自己管理清除。


            **********原信***************************************************

            問幾個(gè)我比較混亂的問題。
            看一下我寫的對不對
             
            int g_variable; //占編譯后的代碼空間,運(yùn)行時(shí)占內(nèi)存(常住內(nèi)存)
            [Huang]屬于3,程序一運(yùn)行就占內(nèi)存,知道程序退出才釋放
             
            const int c_value = 5;    //占編譯后的代碼空間, 是不是常住內(nèi)存呢?
            [Huang]其實(shí)這個(gè)與是否const無關(guān),如果這句是全局的,那么同上,如果是局部的,那么屬于4
             
            void fun(void)
            {
            static int s_variable;    //占編譯后的代碼空間,運(yùn)行時(shí)占內(nèi)存(常住內(nèi)存)
            int variable;    //fun 被調(diào)用時(shí)放入棧中(占用內(nèi)存)
            }
            [Huang]第一句屬于3, 第二句屬于4
             
            如果我定義一下大一點(diǎn)的數(shù)組,如:
             
            const int c_array[100] = ...;
             
            程序一運(yùn)行時(shí)就會(huì)被分配 400 Byte 的內(nèi)存空間嗎?還是在我使用它時(shí)會(huì)被分配400 Byte 的內(nèi)存空間嗎?
            [Huang]還是那句話,是全局的,那么 程序一運(yùn)行時(shí)就會(huì)被分配 400 Byte 的內(nèi)存空間, 如果是局部的,那么在我使用它時(shí)會(huì)才會(huì)被分配400 Byte 的內(nèi)存空間
             
            你這里多次提到const, 其實(shí)const與這個(gè)主題并沒有關(guān)系。的確,const與static聲明的全局變量具有內(nèi)部鏈接的特性,但是即使在每個(gè)obj里都有一個(gè)此變量的拷貝,也不影響其內(nèi)存在靜態(tài)區(qū)的分配。
            posted on 2007-09-13 00:01 SmartPtr 閱讀(1152) 評(píng)論(5)  編輯 收藏 引用

            FeedBack:
            # re: 答學(xué)弟問之變量與內(nèi)存問題
            2007-09-13 00:36 | aGAric
            還有一點(diǎn),如果你的全局變量是初始化過的
            比如
            staitc int array[100] = {0};

            那么你的編出來的.o ,或者是.exe也會(huì)大出 100*sizeof(int)。 如果沒有初始化,那么他們放在bss段,就不占程序code的大小了。

            const 還是有區(qū)別的, const的變量可能是在只讀的數(shù)據(jù)區(qū)域。  回復(fù)  更多評(píng)論
              
            # re: 答學(xué)弟問之變量與內(nèi)存問題
            2007-09-13 09:05 | SmartPtr
            我的理解是這樣的:
            1. 靜態(tài)存儲(chǔ)區(qū)又分為靜態(tài)初始化存儲(chǔ)區(qū)和靜態(tài)未初始化存儲(chǔ)區(qū),正如你說的,前者對應(yīng).data段,后者對應(yīng)bss段, 但是不論在哪個(gè)段,都要占程序內(nèi)存空間的吧

            2. const變量應(yīng)該只是編譯器語法上的一個(gè)限制,數(shù)據(jù)會(huì)在哪個(gè)存儲(chǔ)區(qū)并不由其決定, 事實(shí)上, 繞過C++語法,改變const值是很容易的:
            const int ci = 10;
            __asm
            {
            mov eax, 100;
            mov ci, eax;
            }  回復(fù)  更多評(píng)論
              
            # re: 答學(xué)弟問之變量與內(nèi)存問題
            2007-09-13 23:27 | aGAric
            bss段只記著這里有一個(gè)數(shù)組,大小是多少就占一點(diǎn)空間,data段里面需要占用整個(gè)變量的大小。

            某些編譯器的實(shí)現(xiàn),確實(shí)會(huì)把const 的數(shù)據(jù)放在只讀段, 你當(dāng)然可以寫那個(gè)地址,但系統(tǒng)可能會(huì)拋出一個(gè)異常。  回復(fù)  更多評(píng)論
              
            # re: 答學(xué)弟問之變量與內(nèi)存問題
            2008-08-19 11:42 | Matrix
            這樣改不了const的值哇@SmartPtr
              回復(fù)  更多評(píng)論
              
            # re: 答學(xué)弟問之變量與內(nèi)存問題
            2008-09-17 22:54 | Dandelion
            添加volatile關(guān)鍵字,就看到了
            const volatile int ci = 10;
            __asm
            {
            mov eax, 100;
            mov ci, eax;
            }

            不加volatile關(guān)鍵字的話,編譯器發(fā)現(xiàn)在自己的可見范圍內(nèi)ci沒有被改變,于是就假設(shè)_asm{}之后ci的值沒變,導(dǎo)致生成的匯編代碼為:
            push 0Ah

            加了關(guān)鍵字后,編譯器就不會(huì)對ci做任何的假設(shè),于是生成的匯編代碼變成了這樣:
            mov eax,dword ptr[i]
            push eax  回復(fù)  更多評(píng)論
              

            只有注冊用戶登錄后才能發(fā)表評(píng)論。
            網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


            久久久国产精品| 东方aⅴ免费观看久久av| 国产福利电影一区二区三区久久久久成人精品综合 | 亚洲欧美成人综合久久久| 久久www免费人成看片| 91久久精一区二区三区大全| 精品久久久久久99人妻| 亚洲中文精品久久久久久不卡| 四虎国产精品免费久久5151| 久久热这里只有精品在线观看| 四虎国产精品免费久久5151| 亚洲精品国产美女久久久| 久久久WWW成人免费精品| 国产午夜免费高清久久影院| 伊人久久大香线蕉无码麻豆| 久久久青草久久久青草| 人妻无码中文久久久久专区| 一本一道久久a久久精品综合| 久久久综合九色合综国产| 人妻无码αv中文字幕久久| 久久夜色精品国产亚洲av| 久久亚洲国产精品一区二区| 久久婷婷五月综合色奶水99啪| 亚洲国产精品嫩草影院久久 | 国产V综合V亚洲欧美久久| 亚洲愉拍99热成人精品热久久| 久久成人小视频| 亚洲人成无码久久电影网站| 欧美性猛交xxxx免费看久久久| 久久国产精品-国产精品| 国产精品久久久久天天影视| 久久WWW免费人成一看片| 久久精品国产亚洲AV不卡| 久久久久亚洲av成人网人人软件 | 日韩精品无码久久久久久| 久久亚洲私人国产精品| 成人妇女免费播放久久久| 久久久91精品国产一区二区三区| 久久精品九九亚洲精品天堂| 国产精品欧美久久久久无广告 | 国产精品久久波多野结衣|