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

            牽著老婆滿街逛

            嚴以律己,寬以待人. 三思而后行.
            GMail/GTalk: yanglinbo#google.com;
            MSN/Email: tx7do#yahoo.com.cn;
            QQ: 3 0 3 3 9 6 9 2 0 .

            volatile的用法

            避免編譯器優化的用法 轉自<海濤的筆記>?? _lindwen
              
              
              volatile的本意是“易變的”
              
              由于訪問寄存器的速度要快過RAM,所以編譯器一般都會作減少存取外部RAM的優化。比如:
              
              static int i=0;
              
              int main(void)
              {
              ...
              while (1)
              {
              if (i) dosomething();
              }
              }
              
              /* Interrupt service routine. */
              void ISR_2(void)
              {
              i=1;
              }
              
              程序的本意是希望ISR_2中斷產生時,在main當中調用dosomething函數,但是,由于編譯器判斷在main函數里面沒有修改過i,因此
              可能只執行一次對從i到某寄存器的讀***作,然后每次if判斷都只使用這個寄存器里面的“i副本”,導致dosomething永遠也不會被
              調用。如果將將變量加上volatile修飾,則編譯器保證對此變量的讀寫***作都不會被優化(肯定執行)。此例中i也應該如此說明。
              
              一般說來,volatile用在如下的幾個地方:
              
              1、中斷服務程序中修改的供其它程序檢測的變量需要加volatile;
              
              2、多任務環境下各任務間共享的標志應該加volatile;
              
              3、存儲器映射的硬件寄存器通常也要加volatile說明,因為每次對它的讀寫都可能由不同意義;
              
              另外,以上這幾種情況經常還要同時考慮數據的完整性(相互關聯的幾個標志讀了一半被打斷了重寫),在1中可以通過關中斷來實
              現,2中可以禁止任務調度,3中則只能依靠硬件的良好設計了。
              
              
              
              volatile 的含義
              volatile總是與優化有關,編譯器有一種技術叫做數據流分析,分析程序中的變量在哪里賦值、在哪里使用、在哪里失效,分析結果可以用于常量合并,常量傳播等優化,進一步可以死代碼消除。但有時這些優化不是程序所需要的,這時可以用volatile關鍵字禁止做這些優化,volatile的字面含義是易變的,它有下面的作用:
              
              1 不會在兩個***作之間把volatile變量緩存在寄存器中。在多任務、中斷、甚至setjmp環境下,變量可能被其他的程序改變,編譯器 自己無法知道,volatile就是告訴編譯器這種情況。
              
              2 不做常量合并、常量傳播等優化,所以像下面的代碼:
              volatile int i = 1;
              if (i > 0) ...
              
              if的條件不會當作無條件真。
              
              3 對volatile變量的讀寫不會被優化掉。如果你對一個變量賦值但后面沒用到,編譯器常常可以省略那個賦值***作,然而對Memory Mapped IO的處理是不能這樣優化的。
              
              前面有人說volatile可以保證對內存***作的原子性,這種說法不大準確,其一,x86需要LOCK前綴才能在SMP下保證原子性,其二,RISC根本不能對內存直接運算,要保證原子性得用別的方法,如atomic_inc。
              
              對于jiffies,它已經聲明為volatile變量,我認為直接用jiffies++就可以了,沒必要用那種復雜的形式,因為那樣也不能保證原子性。
              
              你可能不知道在Pentium及后續CPU中,下面兩組指令
              
              inc jiffies
              ;;
              mov jiffies, %eax
              inc %eax
              mov %eax, jiffies
              
              作用相同,但一條指令反而不如三條指令快。

            posted on 2007-03-26 15:47 楊粼波 閱讀(186) 評論(0)  編輯 收藏 引用

            久久久这里只有精品加勒比 | 久久久久久国产a免费观看黄色大片| www久久久天天com| 91精品国产综合久久香蕉| 国产无套内射久久久国产| 亚洲精品无码久久毛片| 国产婷婷成人久久Av免费高清| 日韩一区二区久久久久久| 久久精品国产男包| 99久久精品国产综合一区| 日韩欧美亚洲综合久久| 日韩精品国产自在久久现线拍| 色诱久久av| 91精品无码久久久久久五月天 | 93精91精品国产综合久久香蕉| 久久亚洲国产最新网站| 亚洲国产精品久久久久网站 | 日本WV一本一道久久香蕉| 伊人丁香狠狠色综合久久| 无码人妻久久一区二区三区免费丨| 伊人丁香狠狠色综合久久| 国产婷婷成人久久Av免费高清| 久久久这里有精品| 久久久WWW成人| 国产精品美女久久久免费| 久久精品人人做人人爽电影蜜月| 人人狠狠综合久久亚洲| AAA级久久久精品无码区| 99国产欧美久久久精品蜜芽| 亚洲精品白浆高清久久久久久| 欧洲性大片xxxxx久久久| 国产农村妇女毛片精品久久| 亚洲伊人久久大香线蕉苏妲己| 日韩人妻无码精品久久久不卡 | 94久久国产乱子伦精品免费| 99久久国语露脸精品国产| 久久久精品国产sm调教网站| 久久精品国产99国产精品导航 | 日产精品99久久久久久| 国内精品人妻无码久久久影院导航| 久久综合九色综合久99|