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

            最新隨筆

            搜索

            最新隨筆

            最新評論

            閱讀排行榜

            評論排行榜

            久久ZYZ资源站无码中文动漫| 一个色综合久久| 国产福利电影一区二区三区久久老子无码午夜伦不 | 亚洲AV无码久久| 99久久99久久精品国产片果冻| 中文字幕精品无码久久久久久3D日动漫| 色偷偷偷久久伊人大杳蕉| 久久精品免费网站网| 2019久久久高清456| 久久久无码精品午夜| 久久99国内精品自在现线| 色综合合久久天天给综看| 久久免费线看线看| 久久国产免费直播| 久久国产成人午夜AV影院| 久久99国产精品久久99果冻传媒| 亚洲国产精品嫩草影院久久| 国产女人aaa级久久久级| 久久大香香蕉国产| 久久亚洲欧美国产精品 | 精品一区二区久久| 亚洲AV日韩精品久久久久久| 亚洲精品tv久久久久| 久久91这里精品国产2020| 国产精品一区二区久久| 久久亚洲精品无码VA大香大香| 亚洲人成无码网站久久99热国产| 九九热久久免费视频| 久久精品综合一区二区三区| 亚洲欧美日韩精品久久| 一级做a爰片久久毛片人呢| 国产亚洲美女精品久久久久狼| 亚洲国产另类久久久精品小说| 久久久噜噜噜久久中文字幕色伊伊 | 久久香蕉国产线看观看精品yw| 中文字幕日本人妻久久久免费| 精品久久久无码人妻中文字幕| 99久久无色码中文字幕人妻| 久久精品国产久精国产果冻传媒 | 久久精品成人免费网站| 亚洲乱亚洲乱淫久久|