• <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 閱讀(2059) 評論(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)

            最新隨筆

            搜索

            最新隨筆

            最新評論

            閱讀排行榜

            評論排行榜

            久久这里只有精品久久| 亚洲国产精品高清久久久| 91精品免费久久久久久久久| 久久精品国产99国产精偷| 国产精品久久久亚洲| 日本三级久久网| 亚洲精品第一综合99久久| 国内精品久久久久影院薰衣草| 久久久久久午夜成人影院| 久久久无码精品午夜| 久久精品国产亚洲AV蜜臀色欲 | 久久精品无码一区二区WWW| 精品久久久久久久久免费影院| 国产精品国色综合久久| 国产亚洲色婷婷久久99精品91| 久久99精品国产麻豆宅宅| 国产AⅤ精品一区二区三区久久| 草草久久久无码国产专区| 久久国产成人| 精品精品国产自在久久高清| 国产免费久久精品99re丫y| 91视频国产91久久久| 精品久久久久久中文字幕大豆网| 777久久精品一区二区三区无码| 男女久久久国产一区二区三区| 人人狠狠综合久久亚洲高清| 99久久国产亚洲高清观看2024| 久久精品午夜一区二区福利| 国产美女亚洲精品久久久综合| 国产三级观看久久| 久久99国产精品久久久| 久久er99热精品一区二区| 久久亚洲中文字幕精品一区| 午夜精品久久久久成人| 国产福利电影一区二区三区久久久久成人精品综合 | 亚洲精品第一综合99久久| 99久久人人爽亚洲精品美女| 9久久9久久精品| 色综合久久最新中文字幕| 国产欧美久久久精品| 久久精品国产99久久久|