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

            最新隨筆

            搜索

            最新隨筆

            最新評論

            閱讀排行榜

            評論排行榜

            麻豆av久久av盛宴av| 精品久久一区二区三区| 国产亚洲成人久久| 午夜福利91久久福利| 欧美黑人激情性久久| 久久久久久久亚洲精品| 91精品国产综合久久久久久| 欧美无乱码久久久免费午夜一区二区三区中文字幕 | 久久久国产亚洲精品| 久久久久国产一级毛片高清版| 中文成人久久久久影院免费观看| 久久国产高潮流白浆免费观看| 久久久久亚洲AV成人网人人网站 | 国产成人久久精品一区二区三区 | 国产精品久久久久天天影视| 久久精品国产只有精品66| 思思久久99热只有频精品66| 国产成人精品白浆久久69 | 91久久精一区二区三区大全| 久久久久女教师免费一区| 国产成人综合久久精品红| 精品久久久久久中文字幕| 久久久久国产精品人妻| 7777精品伊人久久久大香线蕉| 国产精品无码久久久久久| 2020久久精品亚洲热综合一本| 国产 亚洲 欧美 另类 久久| 国产亚洲精久久久久久无码| 一个色综合久久| 国产精品成人99久久久久91gav| 亚洲国产精品久久电影欧美| 午夜久久久久久禁播电影| 区亚洲欧美一级久久精品亚洲精品成人网久久久久 | 久久亚洲AV成人无码国产| 无码精品久久一区二区三区| 日本精品久久久中文字幕| 97精品伊人久久大香线蕉app| 亚洲愉拍99热成人精品热久久| 久久亚洲视频| 一本久久免费视频| 久久一区二区三区免费|