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

            關于關鍵字volatile使用

            其實關鍵字volatile大家的說法都差不多,但是很少有一個簡單的程序來觀測結果或者說狀態

            OK,上個簡單的程序,在這里將很好的說明volatile關鍵字 1 #include <stdio.h>
             1 #include <stdio.h>
             2 
             3 int main(void)
             4 {
             5     volatile int z = 1;
             6     int m = (++z) + (++z) + (++z);
             7 
             8     printf("m = %d\n", m);
             9 
            10     return 0;
            11 }
            12 

            如果不加上volatile關鍵字,在不同的編譯器下有不同的結果,有的是10,有的是12,
            加上volatile關鍵字后在gcc上就能得到正常的結果了,但是在VC下依舊不能得到想要的結果,一直沒
            也沒想通為什么,希望知道結果的通知回帖。

            posted on 2011-06-17 11:59 Hallelujah 閱讀(2056) 評論(8)  編輯 收藏 引用 所屬分類: C++學習

            評論

            # re: 關于關鍵字volatile使用 2011-06-17 13:49 天衣有縫

            gcc-4.4.4

            不加volatile結果是10
            加上結果是9

            vc編譯器應該是在 int m = (++z) + (++z) + (++z);語句 之前設置寄存器遍歷保存3次++的結果,然后再參與計算。所以得到12

            所以這段代碼加上volatile仍然是沒有移植性的  回復  更多評論   

            # re: 關于關鍵字volatile使用 2011-06-17 13:51 airtrack

            這個跟volatile沒關系的,int m = (++z) + (++z) + (++z);這個東西的求值順序標準沒有規定,不同編譯器的實現是不同的。  回復  更多評論   

            # re: 關于關鍵字volatile使用 2011-06-17 14:24 Hallelujah

            @airtrack
            肯定的,編譯器實現不同,得到了不同的結果,問題是在gcc下,如果不加volatile產生的結果和加上就是不一樣  回復  更多評論   

            # re: 關于關鍵字volatile使用 2011-06-17 14:31 Hallelujah

            謝謝你的評論,我也認為沒有可移植性,但是至少在Linux下用gcc編譯器是可行的@天衣有縫
              回復  更多評論   

            # re: 關于關鍵字volatile使用 2011-06-17 14:35 airtrack

            “加上volatile關鍵字后在gcc上就能得到正常的結果了”什么是你想要的正常結果?既然標準既沒有規定求值順序,那你的想要的"正常結果"即使在你使用了某種特殊的方法后得到了,那換了一個編譯器之后也不一定就是你想要的。標準沒有規定求值順序,決定權自然是有各個編譯器掌握,而gcc自然有權利決定加volatile和不加volatile的結果是否相同。  回復  更多評論   

            # re: 關于關鍵字volatile使用[未登錄] 2011-06-17 14:53 nscboy

            @airtrack
            我覺得也是這樣.
            但C++標準沒有規定該操作是未定義的.所以大家還可以使用運算符先后順序進行演算.最后得出一個"正確"的結論.并可以要求編譯器支持
            未定義的表達式為:
            z = (++z) + (++z) + (++z);
            這個表達式就仁者見仁,智者見智了.  回復  更多評論   

            # re: 關于關鍵字volatile使用 2011-06-18 18:01 哈哈愛護的吧

            你用了C語言里的未定義行為  回復  更多評論   

            # re: 關于關鍵字volatile使用 2011-06-21 09:48 lugesot

            volatile會對程序結果產生影響。但(++z) + (++z) + (++z)確實是沒有標準的,標準沒有定義,這個寫法,據說已經公認地被禁止了。也就是說,是很臭的寫法。  回復  更多評論   

            <2011年6月>
            2930311234
            567891011
            12131415161718
            19202122232425
            262728293012
            3456789

            導航

            統計

            常用鏈接

            留言簿(1)

            隨筆分類(15)

            隨筆檔案(14)

            最新隨筆

            搜索

            最新隨筆

            最新評論

            閱讀排行榜

            評論排行榜

            一本一本久久A久久综合精品 | 国产精品无码久久四虎| 熟妇人妻久久中文字幕| 久久精品亚洲日本波多野结衣| 99久久无码一区人妻a黑| 伊人久久综在合线亚洲2019| 色综合久久久久综合99| 久久AV无码精品人妻糸列| 欧美精品一本久久男人的天堂| 免费一级欧美大片久久网| 亚洲中文字幕无码久久2017 | 免费国产99久久久香蕉| 欧美日韩精品久久久免费观看| 亚洲AV无一区二区三区久久| 国内精品久久久久久不卡影院| 97视频久久久| 精品人妻伦九区久久AAA片69| 久久国产精品久久| 成人综合久久精品色婷婷| 青草影院天堂男人久久| 午夜精品久久久久久99热| 国产精品免费久久久久久久久| 久久九九久精品国产免费直播| 久久精品一区二区影院| 狠狠色丁香久久婷婷综| 欧美一区二区三区久久综| 婷婷久久五月天| 亚洲第一永久AV网站久久精品男人的天堂AV | 色综合久久88色综合天天| 奇米综合四色77777久久| 香港aa三级久久三级老师2021国产三级精品三级在 | 日本强好片久久久久久AAA| 亚洲国产成人精品无码久久久久久综合 | 欧美亚洲日本久久精品| 色偷偷888欧美精品久久久| 久久青青草原综合伊人| 久久国产精品99国产精| 久久婷婷五月综合国产尤物app| 久久久久久久久久久久久久| 亚洲国产精品成人久久蜜臀 | 国产国产成人久久精品|