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

road420

導航

<2009年11月>
25262728293031
1234567
891011121314
15161718192021
22232425262728
293012345

統計

常用鏈接

留言簿(2)

隨筆檔案

文章檔案

搜索

最新評論

閱讀排行榜

評論排行榜

關鍵字

mutable關鍵字

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

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

例如:
class Demo
{
public:
??? Demo(){}
??? ~Demo(){}
public:
??? bool getFlag() const
??? {
??????? m_nAccess++;
??????? return m_bFlag;
??? }
private:
??? int? m_nAccess;
??? bool m_bFlag;
};

int main()
{
??? return 0;
}

編譯上面的代碼會出現 error C2166: l-value specifies const object的錯誤
說明在const類型的函數中改變了類的非靜態數據成員.

這個時候需要使用mutable來修飾一下要在const成員函數中改變的非靜態數據成員
m_nAccess,代碼如下:

class Demo
{
public:
??? Demo(){}
??? ~Demo(){}
public:
??? bool getFlag() const
??? {
??????? m_nAccess++;
??????? return m_bFlag;
??? }
private:
??? mutable int? m_nAccess;
??? bool m_bFlag;
};

int main()
{
??? return 0;
}

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

?

?

volatile關鍵字

volatile是c/c++中一個鮮為人知的關鍵字,該關鍵字告訴編譯器不要持有變量的臨時拷貝,它可以適用于基礎類型
如:int,char,long......也適用于C的結構和C++的類。當對結構或者類對象使用volatile修飾的時候,結構或者
類的所有成員都會被視為volatile.

使用volatile并不會否定對CRITICAL_SECTION,Mutex,Event等同步對象的需要
例如:
int i;
i = i + 3;
無論如何,總是會有一小段時間,i會被放在一個寄存器中,因為算術運算只能在寄存器中進行。一般來說,volatitle
關鍵字適用于行與行之間,而不是放在行內。

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

void getKey(char* pch)
{
?while (*pch == 0)
??;
}

當你在VC開發環境中將最優化選項都關閉之后,編譯這個程序,將獲得以下結果(匯編代碼)
;?????? while (*pch == 0)
$L27
?; Load the address stored in pch
?mov eax, DWORD PTR _pch$[ebp]
?; Load the character into the EAX register
?movsx eax, BYTE PTR [eax]
?; Compare the value to zero
?test eax, eax
?; If not zero, exit loop
?jne $L28
?;
?jmp $L27
$L28
;}

這段沒有優化的代碼不斷的載入適當的地址,載入地址中的內容,測試結果。效率相當的低,但是結果非常準確

現在我們再來看看將編譯器的所有最優化選項開關都打開以后,重新編譯程序,生成的匯編代碼,和上面的代碼
比較一下有什么不同
;{
?; Load the address stored in pch
?mov eax, DWORD PTR _pch$[esp-4]
?; Load the character into the AL register
?movsx al, BYTE PTR [eax]
;?while (*pch == 0)
?; Compare the value in the AL register to zero
?test al, al
?; If still zero, try again
?je SHORT $L84
?;
;}

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

void getKey(volatile char* pch)
{
?while (*pch == 0)
??;
}

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

;{
?; Load the address stored in pch
?mov eax, DWORD PTR _pch$[esp-4]
;?????? while (*pch == 0)
$L84:
?; Directly compare the value to zero
?cmp BYTE PTR [eax], 0
?; If still zero, try again
?je SHORT $L84
?;
;}

這次的修改結果比較完美,地址不會改變,所以地址聲明被移動到循環之外。地址內容是volatile,所以每次循環
之中它不斷的被重新檢查。

把一個const volatile變量作為參數傳遞給函數是合法的。如此的聲明意味著函數不能改變變量的值,但是變量的
值卻可以被另一個線程在任何時間改變掉。


explicit關鍵字


我們在編寫應用程序的時候explicit關鍵字基本上是很少使用,它的作用是"禁止單參數構造函數"被用于自動型別轉換,
其中比較典型的例子就是容器類型,在這種類型的構造函數中你可以將初始長度作為參數傳遞給構造函數.
例如:
你可以聲明這樣一個構造函數
class Array
{
public:
?explicit Array(int size);
?......
};
在這里explicit關鍵字起著至關重要的作用,如果沒有這個關鍵字的話,這個構造函數有能力將int轉換成Array.一旦這種
情況發生,你可以給Array支派一個整數值而不會引起任何的問題,比如:
Array arr;
...
arr = 40;
此時,C++的自動型別轉換會把40轉換成擁有40個元素的Array,并且指派給arr變量,這個結果根本就不是我們想要的結果.如果
我們將構造函數聲明為explicit,上面的賦值操作就會導致編譯器報錯,使我們可以及時發現錯誤.
需要注意的是:explicit同樣也能阻止"以賦值語法進行帶有轉型操作的初始化";
例如:
Array arr(40);//正確
Array arr = 40;//錯誤

看一下以下兩種操作:
X x;
Y y(x);//顯式類型轉換
另一種
X x;
Y y = x;//隱式類型轉換

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

?

__based關鍵字


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

typedef struct tagDEMOSTRUCT {
?int a;
?char sz[10];
} DEMOSTRUCT, * PDEMOSTRUCT;

HANDLE hFileMapping = CreateFileMapping(...);
LPVOID lpShare = (LPDWORD)MapViewOfFile(...);

DEMOSTRUCT __based(lpShare)* lpDemo;

上面的例子聲明了一個指針lpDemo,內部儲存的是從lpShare開始的偏移值,也就是lpHead是以lpShare為基準的偏移值.
上面的例子種的DEMOSTRUCT只是隨便定義的一個結構,用來代表任意的結構.

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

在這里我只是介紹了幾個并不時很常見的關鍵字的意義即用法,其他那些常見的關鍵字介紹他們的文章已經不少了在這里
就不再一一介紹了.希望這些內容能對大家有一定的幫助!

posted on 2006-10-22 16:07 深邃者 閱讀(175) 評論(0)  編輯 收藏 引用

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            午夜精品一区二区三区在线视| 亚洲午夜在线观看视频在线| 日韩午夜激情av| 欧美韩国在线| 在线视频欧美日韩| 亚洲视频你懂的| 黄色av一区| 亚洲国产精品va在线看黑人动漫| 久久亚洲综合网| 夜夜嗨av色综合久久久综合网| 亚洲日本欧美日韩高观看| 国产精品国产三级国产aⅴ浪潮| 久久永久免费| 亚洲专区免费| 欧美精品系列| 牛牛国产精品| 国产一区二区日韩精品| 亚洲人成小说网站色在线| 国产女人精品视频| 国产午夜精品一区理论片飘花| 另类亚洲自拍| 国产精品视频网址| 亚洲理论在线| 亚洲精品一区中文| 美女尤物久久精品| 久久成人人人人精品欧| 欧美国产日本| 亚洲国产日韩欧美综合久久| 一区二区在线视频播放| 亚洲自拍偷拍视频| 亚欧成人在线| 狠狠入ady亚洲精品| 午夜在线视频观看日韩17c| 亚洲免费小视频| 国产欧美一区二区三区沐欲| 99re热精品| 亚洲免费视频观看| 国产亚洲毛片| 久久综合免费视频影院| 欧美国产一区二区| 99热精品在线观看| 欧美日韩亚洲视频一区| 亚洲美女免费视频| 欧美一区二区精品久久911| 狠狠色香婷婷久久亚洲精品| 久久精品夜色噜噜亚洲a∨| 欧美激情一区二区三区四区 | 久久成人综合网| 国产亚洲午夜| 欧美成人激情视频| 亚洲精品乱码久久久久久久久| 亚洲缚视频在线观看| 欧美午夜一区二区福利视频| 中文日韩在线| 欧美激情一区二区三区在线视频观看| 国模吧视频一区| 亚洲欧美日韩在线高清直播| 久久精品夜色噜噜亚洲aⅴ| 亚洲国产精品一区在线观看不卡| 国产精品久久久久7777婷婷| 久久人91精品久久久久久不卡 | 99精品视频免费| 久久视频在线看| 亚洲专区免费| 亚洲一区欧美| 日韩性生活视频| 亚洲丁香婷深爱综合| 国产亚洲一二三区| 国产综合视频| 国内精品嫩模av私拍在线观看| 欧美系列电影免费观看| 欧美日韩国产精品一区| 欧美国产激情| 欧美极品一区| 欧美片在线观看| 国产精品成人va在线观看| 欧美日韩国产一级片| 欧美日本在线一区| 国产精品初高中精品久久| 国产精品国产a| 国产农村妇女精品一二区| 国产一区激情| 欧美一区二区在线免费观看| 一区二区三区高清在线| 亚洲欧美欧美一区二区三区| 欧美一区二区国产| 久久精品99国产精品酒店日本| 一本色道久久综合亚洲精品按摩 | 欧美伊久线香蕉线新在线| 欧美一区亚洲| 亚洲人成毛片在线播放女女| 99国产精品国产精品毛片| 亚洲一区二区日本| 午夜在线一区二区| 美腿丝袜亚洲色图| 国产伦精品一区二区三区在线观看| 国产精品免费久久久久久| 伊人男人综合视频网| 中文在线一区| 欧美激情一级片一区二区| 亚洲视频一区| 欧美黄色一区| 亚洲黄网站在线观看| 久久国产婷婷国产香蕉| 一区二区三区成人精品| 麻豆国产精品一区二区三区| 国产伦理一区| 亚洲一区二区三区欧美| 亚洲精品久久久一区二区三区| 欧美亚洲日本一区| 国产精品久久久久天堂| 一区二区三区 在线观看视频 | 欧美诱惑福利视频| 99精品国产高清一区二区| 欧美大片免费观看| 亚洲激情女人| 亚洲激情亚洲| 欧美日韩一区二区三区免费看| 小处雏高清一区二区三区| 欧美午夜精品久久久久久孕妇| 亚洲人成毛片在线播放女女| 亚洲大胆美女视频| 欧美成人高清视频| 亚洲伦理一区| 亚洲尤物视频在线| 国产视频在线观看一区二区| 久久久精品午夜少妇| 久久久综合网站| 亚洲色图在线视频| 性欧美在线看片a免费观看| 国产一区二区三区在线观看精品 | 一区免费在线| 欧美成人激情视频免费观看| 久久偷窥视频| 亚洲午夜精品久久久久久app| 亚洲综合不卡| 99re66热这里只有精品3直播| 欧美激情网站在线观看| 99re热这里只有精品免费视频| 99视频精品免费观看| 亚洲精品视频一区| 国产专区一区| 亚洲欧美激情精品一区二区| 黄色精品一区| 亚洲影音先锋| 亚洲综合色在线| 欧美日韩中文在线| 亚洲第一中文字幕| 性做久久久久久| 亚洲欧美日韩一区二区| 欧美日韩视频免费播放| 欧美激情第10页| 在线欧美不卡| 久久久久久精| 欧美sm视频| 亚洲高清中文字幕| 免费一区二区三区| 国产视频在线观看一区| 亚洲欧美日本日韩| 欧美在线看片a免费观看| 国产精品自拍一区| 久久国产一区二区三区| 久久亚洲春色中文字幕久久久| 国产亚洲午夜| 女人天堂亚洲aⅴ在线观看| 欧美激情精品久久久久| 日韩亚洲精品在线| 国产精品伦子伦免费视频| 欧美在线国产| 欧美激情乱人伦| 亚洲女人天堂成人av在线| 国产日韩高清一区二区三区在线| 欧美一区二区三区另类 | 久久精品欧洲| 尤物九九久久国产精品的分类| 亚洲精品视频在线看| 亚洲三级影院| 国产人成精品一区二区三| 一区二区三区波多野结衣在线观看| 亚洲视频在线观看网站| 国产欧美一区二区三区国产幕精品| 久久精品国产视频| 亚洲精品一区二区三区樱花 | 久久久久久免费| 日韩一级黄色片| 欧美激情一区二区在线| 欧美在线一区二区| 亚洲天堂av综合网| 亚洲国产一区二区精品专区| 国产精品亚洲精品| 欧美精品一区二区三区在线看午夜| 欧美自拍偷拍午夜视频| 亚洲一区二区在| 亚洲欧美成人网| 亚洲欧美日韩国产精品| 中国成人黄色视屏| 亚洲深爱激情| 欧美在线关看| 久久久久久9| 久久久久久久成人|