c/c++中的近指令、遠指標和巨指標
宋寶華 email:[email protected] sweek
在我們的c/c++學習生涯中、在我們大腦的印象裡,通常只有指標的概念,很少聽說指標還有遠、近、巨之分的,從沒聽說過什麼近指標、遠指標和巨指標。
可以,某年某月的某一天,你突然看到這樣的語句:
char near *p; /*
定義乙個字元型「近」指標*/
char far *p; /*
定義乙個字元型「遠」指標*/
char huge *p; /*
定義乙個字元型「巨」指標*/
實在不知道語句中的「near」、「far」、「huge」是從**冒出來的,是個什麼概念!本文試圖對此進行解答,解除許多人的困惑。
因此,在16位處理器環境下,如果訪問本段內位址的值,用乙個16位的指標(表示段內偏移)就可以訪問到;而要訪問本段以外位址的值,則需要用16位的段內偏移+16位的段位址,總共32位的指標。
這樣,我們就知道了遠、近指標的區別:
ø 近指標是只能訪問本段、只包含本段偏移的、位寬為16位的指標;
ø 遠指標是能訪問非本段、包含段偏移和段位址的、位寬為32位的指標。
char near *p;
p=(char near *)0xffff;
char far *p;
p=(char far *)0x10000002;
除了遠指標和近指標外,還有乙個巨指標的概念。
和遠指標一樣,巨指標也是32位的指標,指標也表示為16位段:16位偏移,也可以定址任何位址。它和遠指標的區別在於進行了規格化處理。遠指標沒有規格化,可能存在兩個遠指標實際指向同乙個實體地址,但是它們的段位址和偏移位址不一樣,如23b0:0004和23a1:00f4都指向同乙個實體地址 23604!巨指標通過特定的例程保證:每次操作完成後其偏移量均小於10h,即只有最低4位有數值,其餘數值都被進製到段位址上去了,這樣就可以避免 far指標在64k邊界時出乎意料的迴繞的行為。當然,一次操作必須小於64k。下面的函式可以將遠指標轉換為巨指標:
void normalize(void far ** p)
從上面的函式中我們再一次看到了指標之指標的使用,這個函式要修改指標的值,因此必須傳給它的指標的指標作為引數。
講到這裡,筆者要強調的是:近指標、遠指標、巨指標是段定址的16bit處理器的產物(如果處理器是16位的,但是不採用段定址的話,也不存在近指標、遠指標、巨指標的概念),當前普通pc所使用的32bit處理器(80386以上)一般執行在保護模式下的,指標都是32位的,可平滑位址,已經不分遠、近指標了。但是在嵌入式系統領域下,8086的處理器仍然有比較廣泛的市場,如amd公司的am186ed、am186er等處理器,開發這些系統的程式時,我們還是有必要弄清楚指標的定址範圍。
如果讀者還想更透徹地理解本文講解的內容,不妨再溫習一下微機原理、
8086
彙編,並參考
C C 中的近指令 遠指標和巨指標
c c 中的近指令 遠指標和巨指標 宋寶華 email 21cnbao 21cn.com sweek 在我們的c c 學習生涯中 在我們大腦的印象裡,通常只有指標的概念,很少聽說指標還有遠 近 巨之分的,從沒聽說過什麼近指標 遠指標和巨指標 飛鴿傳書 可以,某年某月的某一天,你突然看到這樣的語句 c...
C C 中的近指令 遠指標和巨指標
在我們的c c 學習生涯中 在我們大腦的印象裡,通常只有指標的概念,很少聽說指標還有遠 近 巨之分的,從沒聽說過什麼近指標 遠指標和巨指標。可以,某年某月的某一天,你突然看到這樣的語句 char near p 定義乙個字元型 近 指標 char far p 定義乙個字元型 遠 指標 char hug...
C C 中的近指令 遠指標和巨指標
在我們的c c 學習生涯中 在我們大腦的印象裡,通常只有指標的概念,很少聽說指標還有遠 近 巨之分的,從沒聽說過什麼近指標 遠指標和巨指標。可以,某年某月的某一天,你突然看到這樣的語句 char near p 定義乙個字元型 近 指標 char far p 定義乙個字元型 遠 指標 char hug...