• <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++中const變量真的不可以修改嗎?

            c++中const變量真的不可以修改嗎?

            在學(xué)c++的時候,看到的大部分的書籍對const關(guān)鍵字的介紹都是:const關(guān)鍵字修飾的變量的值是不可被修改的。但是事實真是如此嗎?今天做了一個小的實驗,發(fā)現(xiàn)const變量是可以被修改的。c++代碼如下:           
             1 #include <iostream>
             2 using namespace std;
             3 
             4 int main()
             5 {
             6     const int a = 3;
             7     int* p = const_cast<int*>(&a);
             8     *= 4;
             9     cout << "value of p: " << *<< endl;
            10     cout << "value of a: " << a << endl;
            11     cout << "address of p: " << p << endl;
            12     cout << "address of a: " << &<< endl;
            13 
            14     return 0;
            15 }             
            上面代碼第7行將a的地址賦值給指針p,然后第8行修改p所指向的地址中的值,運行結(jié)果如下:
            運行結(jié)果
            value of p: 4
            value of a: 3
            address of p: 0x7fbffff7fc
            address of a: 0x7fbffff7fc
            如上所示結(jié)果,指針p所指向的地址和變量a的地址相同,但是p所指地址中的值已經(jīng)發(fā)生改變。但是為何變量a對應(yīng)的地址中的值已經(jīng)由3變?yōu)?,但是a的值確實3呢?
            暫時把這個問題擱淺。再來看一下如下的c++代碼:
             1 #include <iostream>
             2 using namespace std;
             3 const int a = 3;
             4 int main()
             5 {
             6     //const int a = 3;
             7     int* p = const_cast<int*>(&a);
             8     *= 4;
             9     cout << "value of p: " << *<< endl;
            10     cout << "value of a: " << a << endl;
            11     cout << "address of p: " << p << endl;
            12     cout << "address of a: " << &<< endl;
            13 
            14     return 0;
            15 }
            如上代碼g++編譯通過,在運行時報錯如下:
            輸出結(jié)果
            Segmentation fault (core dumped)
            由此可見,在c++中全局const變量和局部const變量的編譯器處理的方法是不一樣的。查閱資料得知,全局const變量是不分配內(nèi)存地址的,它編譯器放置在符號表中作為編譯期常量,全局const變量放在只讀數(shù)據(jù)段中,受到只讀數(shù)據(jù)段的權(quán)限保護(hù),當(dāng)你修改一個只讀數(shù)據(jù)段中的內(nèi)容時,會得到一個運行時錯誤。而局部const變量是放在堆棧之中,因為在內(nèi)存中有地址,通過修改地址中的值可以達(dá)到修改const所指內(nèi)存中值的目的。

            posted on 2012-04-10 23:49 MrRightLeft 閱讀(3787) 評論(10)  編輯 收藏 引用 所屬分類: C/C++

            評論

            # re: c++中const變量真的不可以修改嗎? 2012-04-11 13:16 迎風(fēng)而立

            這個修改的并不是a的值啊,而是*p的值。*p和a表示同一個單元。但是當(dāng)用3給a賦值之后,是a的值不可以改變,而不是*p的值不可以改變。  回復(fù)  更多評論   

            # re: c++中const變量真的不可以修改嗎?[未登錄] 2012-04-11 14:10 ithaca

            博主還是沒能解釋為什么第一個程序中a的值沒有變?yōu)?  回復(fù)  更多評論   

            # re: c++中const變量真的不可以修改嗎? 2012-04-11 14:20 OUR!!CPP

            const_cast<int*>這里已經(jīng)告訴編譯器把原本放在常量區(qū)的變量移出來了。  回復(fù)  更多評論   

            # re: c++中const變量真的不可以修改嗎? 2012-04-11 16:28 so

            cout << "value of a: " << a << endl;
            \\
            cout << "value of a: " << 3 << endl;  回復(fù)  更多評論   

            # re: c++中const變量真的不可以修改嗎? 2012-04-12 18:09 MrRightLeft

            @OUR!!CPP
            在const_cast<int*>之前打印出a的地址,和應(yīng)用了const_cast<int*>之后的a的地址比較,是相同的。何來變量被從常量區(qū)移出來一說?
              回復(fù)  更多評論   

            # re: c++中const變量真的不可以修改嗎? 2012-04-12 18:12 MrRightLeft

            a這個常量不是從相應(yīng)地址中取出來的。在程序運行時a的值應(yīng)該是從符號表中取出。所以改變a對應(yīng)地址中的值,并不會改變a變量的值@ithaca
              回復(fù)  更多評論   

            # re: c++中const變量真的不可以修改嗎? 2012-04-17 11:00 Coneagoe

            #include <iostream>
            using namespace std;

            int main() {
            const int N = 22;
            int * pN = const_cast<int*>(&N);
            *pN = 33;
            cout << N << '\t' << &N << endl;
            cout << *pN << '\t' << pN << endl;
            }
            Output:

            22 0xbf91cfa0
            33 0xbf91cfa0


            The above output, obtained with gcc version 4.0.3, could be different on your system, because the behavior is undefined.

            In this example, we used const_cast to obtain a regular pointer to a const int. Because the const int is in stack storage class, we don't get a segmentation fault by attempting to change the memory. The compiler is unable to "optimize out" the int, and the const_cast tells it not to even try.

            Ref:
            http://cartan.cas.suffolk.edu/oopdocbook/html/staticcast.html  回復(fù)  更多評論   

            <2012年9月>
            2627282930311
            2345678
            9101112131415
            16171819202122
            23242526272829
            30123456

            導(dǎo)航

            統(tǒng)計

            隨筆分類

            隨筆檔案

            文章分類

            文章檔案

            搜索

            最新評論

            閱讀排行榜

            評論排行榜

            亚洲欧美另类日本久久国产真实乱对白| 久久精品国产欧美日韩99热| 国产精品久久久久9999高清| 久久免费高清视频| 久久九九久精品国产免费直播| 免费一级欧美大片久久网| 久久久久精品国产亚洲AV无码| 三上悠亚久久精品| 国产三级精品久久| 97久久婷婷五月综合色d啪蜜芽 | 国产综合免费精品久久久| 一本色道久久88综合日韩精品 | 国产午夜电影久久| 久久国产亚洲精品| 国产精品久久国产精麻豆99网站| 久久精品一区二区三区中文字幕| 亚洲国产精品无码久久| 亚洲国产精品久久久久婷婷软件| 成人综合久久精品色婷婷| 国产精品久久成人影院| 性高湖久久久久久久久| 久久精品国产精品亜洲毛片| 国产精品九九九久久九九| 中文字幕久久波多野结衣av| 久久久久综合国产欧美一区二区| 久久91精品国产91久久户| 日韩人妻无码一区二区三区久久| 色天使久久综合网天天| 久久久久国产日韩精品网站| 精品久久久无码人妻中文字幕豆芽| 香蕉99久久国产综合精品宅男自| 国产香蕉97碰碰久久人人| 久久电影网2021| 国产精品久久久久久久| 国产精品久久久久国产A级| 久久久精品人妻一区二区三区四| 久久99热这里只有精品国产| 久久久黄色大片| 色综合久久中文字幕无码| 亚洲国产另类久久久精品黑人| 亚洲精品无码久久千人斩|