青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

積木

No sub title

  C++博客 :: 首頁 :: 聯系 :: 聚合  :: 管理
  140 Posts :: 1 Stories :: 11 Comments :: 0 Trackbacks

常用鏈接

留言簿(1)

我參與的團隊

搜索

  •  

最新評論

閱讀排行榜

評論排行榜

下面這個地址,介紹了幾個c++中的關鍵字。還不錯,就收下了。
http://www.shnenglu.com/leetaolion/archive/2011/09/13/46586.html

     mutable關鍵字

    關鍵字mutable是C++中一個不常用的關鍵字,他只能用于類的非靜態和非常量數據成員我們知道一個對象的狀態由該對象的非靜態數據成員決定,所以隨著數據成員的改變,對像的狀態也會隨之發生變化!

如果一個類的成員函數被聲明為const類型,表示該函數不會改變對象的狀態,也就是該函數不會修改類的非靜態數據成員.但是有些時候需要在該類函數中對類的數據成員進行賦值.這個時候就需要用到mutable關鍵字了

例如:


 1class Demo
 2{
 3public:
 4    Demo(){}
 5    ~Demo(){}
 6public:
 7    bool getFlag() const
 8    {
 9        m_nAccess++;
10        return m_bFlag;
11    }

12private:
13    int  m_nAccess;
14    bool m_bFlag;
15}
;
16
17int main()
18{
19    return 0;
20}

21

編譯上面的代碼會出現 error C2166: l-value specifies const object的錯誤說明在const類型的函數中改變了類的非靜態數據成員.這個時候需要使用mutable來修飾一下要在const成員函數中改變的非靜態數據成員

m_nAccess,代碼如下:


 1class Demo
 2{
 3public:
 4    Demo(){}
 5    ~Demo(){}
 6public:
 7    bool getFlag() const
 8    {
 9        m_nAccess++;
10        return m_bFlag;
11    }

12private:
13    mutable int  m_nAccess;
14    bool m_bFlag;
15}
;
16
17int main()
18{
19    return 0;
20}

21

這樣再重新編譯的時候就不會出現錯誤了!

volatile關鍵字

volatile是c/c++中一個鮮為人知的關鍵字,該關鍵字告訴編譯器不要持有變量的臨時拷貝,它可以適用于基礎類型

如:int,char,long......也適用于C的結構和C++的類。當對結構或者類對象使用volatile修飾的時候,結構或者類的所有成員都會被視為volatile.使用volatile并不會否定對CRITICAL_SECTION,Mutex,Event等同步對象的需要

例如:


1int i;
2= i + 3;

無論如何,總是會有一小段時間,i會被放在一個寄存器中,因為算術運算只能在寄存器中進行。一般來說,volatitle關鍵字適用于行與行之間,而不是放在行內。

我們先來實現一個簡單的函數,來觀察一下由編譯器產生出來的匯編代碼中的不足之處,并觀察volatile關鍵字如何修正這個不足之處。在這個函數體內存在一個busy loop(所謂busy loop也叫做busy waits,是一種高度浪費CPU時間的循環方法)


1void getKey(char* pch)
2{
3 while (*pch == 0);
4}

當你在VC開發環境中將最優化選項都關閉之后,編譯這個程序,將獲得以下結果(匯編代碼)


 1;       while (*pch == 0)
 2$L27
 3 ; Load the address stored in pch
 4 mov eax, DWORD PTR _pch$[ebp]
 5 ; Load the character into the EAX register
 6 movsx eax, BYTE PTR [eax]
 7 ; Compare the value to zero
 8 test eax, eax
 9 ; If not zero, exit loop
10 jne $L28
11 ;
12 jmp $L27
13$L28
14;}

這段沒有優化的代碼不斷的載入適當的地址,載入地址中的內容,測試結果。效率相當的低,但是結果非常準確現在我們再來看看將編譯器的所有最優化選項開關都打開以后,重新編譯程序,生成的匯編代碼,和上面的代碼

比較一下有什么不同


 1;
 2 ; Load the address stored in pch
 3 mov eax, DWORD PTR _pch$[esp-4]
 4 ; Load the character into the AL register
 5 movsx al, BYTE PTR [eax]
 6while (*pch == 0)
 7 ; Compare the value in the AL register to zero
 8 test al, al
 9 ; If still zero, try again
10 je SHORT $L84
11 ;
12;}

從代碼的長度就可以看出來,比沒有優化的情況要短的多。需要注意的是編譯器把MOV指令放到了循環之外。這在單線程中是一個非常好的優化,但是,在多線程應用程序中,如果另一個線程改變了變量的值,則循環永遠不會結束。被測試的值永遠被放在寄存器中,所以該段代碼在多線程的情況下,存在一個巨大的BUG。解決方法是重新

寫一次getKey函數,并把參數pch聲明為volatile,代碼如下:


1void getKey(volatile char* pch)
2{
3 while (*pch == 0) ;
4}

這次的修改對于非最優化的版本沒有任何影響,下面請看最優化后的結果:


 1;{
 2 ; Load the address stored in pch
 3 mov eax, DWORD PTR _pch$[esp-4]
 4;       while (*pch == 0)
 5$L84:
 6 ; Directly compare the value to zero
 7 cmp BYTE PTR [eax], 0
 8 ; If still zero, try again
 9 je SHORT $L84
10 ;
11;}

這次的修改結果比較完美,地址不會改變,所以地址聲明被移動到循環之外。地址內容是volatile,所以每次循環之中它不斷的被重新檢查。把一個const volatile變量作為參數傳遞給函數是合法的。如此的聲明意味著函數不能改變變量的值,但是變量的值卻可以被另一個線程在任何時間改變掉。


explicit關鍵字

我們在編寫應用程序的時候explicit關鍵字基本上是很少使用,它的作用是"禁止單參數構造函數"被用于自動型別轉換,其中比較典型的例子就是容器類型,在這種類型的構造函數中你可以將初始長度作為參數傳遞給構造函數.

例如:

你可以聲明這樣一個構造函數


1class Array
2{
3public:
4 explicit Array(int size);
5 
6}
;

在這里explicit關鍵字起著至關重要的作用,如果沒有這個關鍵字的話,這個構造函數有能力將int轉換成Array.一旦這種情況發生,你可以給Array支派一個整數值而不會引起任何的問題,比如:


1Array arr;
2
3arr = 40;

此時,C++的自動型別轉換會把40轉換成擁有40個元素的Array,并且指派給arr變量,這個結果根本就不是我們想要的結果.如果我們將構造函數聲明為explicit,上面的賦值操作就會導致編譯器報錯,使我們可以及時發現錯誤.需要注意的是:explicit同樣也能阻止"以賦值語法進行帶有轉型操作的初始化";

例如:


1Array arr(40);//正確
2Array arr = 40;//錯誤

看一下以下兩種操作:


1X x;
2Y y(x);//顯式類型轉換

另一種


1X x;
2Y y = x;//隱式類型轉換

這兩種操作存在一個小小的差別,第一種方式式通過顯式類型轉換,根據型別x產生了型別Y的新對象;第二種方式通過隱式轉換產生了一個型別Y的新對象.explicit關鍵字的應用主要就是上面所說的構造函數定義種,參考該關鍵字的應用可以看看STL源代碼,其中大量使用了該關鍵字

    __based關鍵字

該關鍵字主要用來解決一些和共享內存有關的問題,它允許指針被定義為從某一點開始算的32位偏移值,而不是內存種的絕對位置

舉個例子:


 1typedef struct tagDEMOSTRUCT {
 2 int a;
 3 char sz[10];
 4}
 DEMOSTRUCT, * PDEMOSTRUCT;
 5
 6HANDLE hFileMapping = CreateFileMapping();
 7LPVOID lpShare = (LPDWORD)MapViewOfFile();
 8
 9DEMOSTRUCT __based(lpShare)* lpDemo;
10

    上面的例子聲明了一個指針lpDemo,內部儲存的是從lpShare開始的偏移值,也就是lpHead是以lpShare為基準的偏移值.

上面的例子種的DEMOSTRUCT只是隨便定義的一個結構,用來代表任意的結構.

雖然__based指針使用起來非常容易,但是,你必須在效率上付出一定的代價.每當你用__based指針處理數據,CPU都必須為它加上基地址,才能指向真正的位置.

posted on 2012-05-29 13:59 Jacc.Kim 閱讀(255) 評論(0)  編輯 收藏 引用 所屬分類: VC / C++
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            一本色道久久综合精品竹菊 | 亚洲精品国产精品乱码不99按摩| 亚洲国产片色| 国产亚洲精品aa午夜观看| 亚洲精品久久久久久久久久久久| 韩国v欧美v日本v亚洲v| 亚洲深夜福利网站| 99综合视频| 欧美粗暴jizz性欧美20| 老司机午夜免费精品视频| 国产精品腿扒开做爽爽爽挤奶网站| 亚洲经典在线| 91久久精品国产91久久性色tv | 国产偷国产偷精品高清尤物| 亚洲精品少妇30p| 亚洲精品久久久久久久久久久久久 | 欧美另类一区二区三区| aa国产精品| 欧美成人激情视频| 欧美国产亚洲另类动漫| 在线免费精品视频| 久久这里只有| 欧美成人a视频| 亚洲国产毛片完整版| 美女黄色成人网| 欧美刺激午夜性久久久久久久| 欧美日韩激情网| 亚洲精品视频免费| 日韩亚洲欧美在线观看| 欧美日韩高清一区| 一区二区三区高清视频在线观看| 在线视频亚洲欧美| 国产精品激情电影| 亚洲——在线| 亚洲精品国产拍免费91在线| 欧美国产日本高清在线| 久久国产一区| 精品盗摄一区二区三区| 久久婷婷一区| 91久久久久久久久| 亚洲午夜在线观看| 国产日韩欧美视频| 久久精品国产一区二区三| 亚洲欧美韩国| 国产主播精品在线| 蜜臀av性久久久久蜜臀aⅴ| 亚洲欧洲一级| 性做久久久久久久久| 精品动漫一区| 欧美精品七区| 性欧美xxxx大乳国产app| 免费一级欧美在线大片| 一二三区精品| 国内不卡一区二区三区| 欧美国产日本在线| 午夜电影亚洲| 最新国产乱人伦偷精品免费网站| 亚洲欧美视频在线观看| 欧美日韩中文字幕日韩欧美| 午夜在线精品偷拍| 亚洲高清视频中文字幕| 小辣椒精品导航| 亚洲精品久久久久久久久久久| 国产精品美女久久久| 亚洲综合日韩在线| 欧美成人激情在线| 午夜精品久久久久久久久久久久| 亚洲大胆视频| 国产精品区一区二区三| 欧美1区2区3区| 小黄鸭精品密入口导航| 亚洲国产一区二区三区青草影视| 欧美影视一区| 日韩性生活视频| 在线观看久久av| 国产精品欧美久久久久无广告| 久久一区二区三区四区| 午夜在线观看免费一区| 亚洲美女黄色片| 女女同性精品视频| 久久成人资源| 亚洲一区二区三区免费观看| 亚洲国产精品成人精品| 国色天香一区二区| 国产精品视频一区二区三区| 欧美日韩日本国产亚洲在线| 蜜臀av性久久久久蜜臀aⅴ| 欧美在线资源| 亚洲欧美一区二区精品久久久| 日韩亚洲国产精品| 欧美一级成年大片在线观看| 这里只有精品电影| 亚洲精品久久久久久一区二区| 黄色国产精品| 韩国三级电影久久久久久| 国产精品夜夜夜| 欧美视频导航| 欧美三级特黄| 欧美三级在线| 欧美三级第一页| 欧美日韩日本国产亚洲在线| 欧美精品在线免费| 欧美激情视频一区二区三区免费 | 久久福利影视| 欧美在线观看一二区| 欧美一区二区三区精品| 亚洲欧美日本日韩| 亚洲欧美视频一区| 午夜日韩视频| 久久av一区二区三区亚洲| 性欧美在线看片a免费观看| 香蕉尹人综合在线观看| 香蕉av777xxx色综合一区| 午夜一区在线| 久久精品国产2020观看福利| 久久久久久久91| 理论片一区二区在线| 欧美成人精品| 欧美日韩在线视频观看| 国产精品视频免费| 国产在线精品成人一区二区三区| 国产一区二区三区免费在线观看 | 91久久精品国产| 99国产精品一区| 亚洲欧美日产图| 久久精品青青大伊人av| 久热国产精品视频| 欧美日韩成人| 国产私拍一区| 悠悠资源网亚洲青| 一本大道久久精品懂色aⅴ| 亚洲欧美电影在线观看| 久久精品网址| 亚洲国产一二三| 亚洲一区二区四区| 久久久亚洲高清| 欧美日韩一区二区三区| 国产欧美韩国高清| 国产精品美腿一区在线看| 国产亚洲精品久久久| 亚洲大胆av| 亚洲欧美综合精品久久成人| 久久免费视频这里只有精品| 亚洲国产美女久久久久| 亚洲一区二区三区四区视频| 久久先锋资源| 国产精品久久久久久久久免费桃花| 国产综合婷婷| 亚洲午夜电影在线观看| 久热爱精品视频线路一| 99re成人精品视频| 久久久免费av| 国产精品自拍在线| 亚洲日本久久| 久久久亚洲午夜电影| 日韩视频精品| 榴莲视频成人在线观看| 国产女主播一区二区三区| 亚洲精品在线免费| 久久久伊人欧美| 亚洲社区在线观看| 欧美高清不卡| 在线日韩av片| 欧美在线播放高清精品| 亚洲乱码国产乱码精品精可以看| 久久精品人人爽| 国产欧美精品一区| 亚洲桃花岛网站| 亚洲激情第一页| 老司机午夜精品视频| 国产自产v一区二区三区c| 亚洲一区二区综合| 亚洲精品在线免费| 欧美国内亚洲| 亚洲欧洲日本一区二区三区| 久久久久9999亚洲精品| 亚洲欧美日韩国产一区二区三区| 欧美精品在线免费播放| 亚洲人午夜精品| 欧美黄免费看| 老色鬼精品视频在线观看播放| 韩国成人精品a∨在线观看| 欧美一区免费| 亚洲欧美日产图| 国产精品久久综合| 亚洲女爱视频在线| 宅男噜噜噜66国产日韩在线观看| 欧美激情久久久久| 亚洲九九精品| 亚洲欧洲日产国码二区| 欧美福利视频网站| 日韩午夜激情电影| 最新国产乱人伦偷精品免费网站| 欧美大片网址| 一区电影在线观看| 一区二区三区三区在线| 国产精品家庭影院| 欧美在线播放| 久久精品99国产精品酒店日本| 极品中文字幕一区|